如何在 WebBrowser 控件中捕获 POST 的结果?
How do you capture the result of a POST in the WebBrowser control?
我有一个带有 WebBrowser control 的 Winforms 表单。
我已经想出了如何将 C# 代码连接到 Web 浏览器控件中的 Javascript,方法是将 C# class 的实例附加到 ObjectForScripting 属性,像这样:
public partial class Browser : Form
{
private void webBrowser1_DocumentCompleted(object sender, WebBrowserDocumentCompletedEventArgs e)
{
webBrowser1.ObjectForScripting = new ScriptInterface();
}
}
[PermissionSet(SecurityAction.Demand, Name = "FullTrust")]
[ComVisible(true)]
public class ScriptInterface
{
public void DoSomething(string data)
{
// Do something interesting with data here
}
}
...然后从 Javascript 调用它,如下所示:
<button onclick=window.external.DoSomething('with this')/>
我还没有弄清楚如何从 WebBrowser 控件中的表单捕获 POST 操作的结果,并在我的 C# 代码中使用它。
您或许可以使用 jQuery post
代替表格 post。
假设您的表单的 ID 为 myForm
:
$( "#myForm" ).submit(function( event ) {
// Stop form from submitting normally
event.preventDefault();
// Get some values from elements on the page:
var $form = $(this),
var term = $form.find("input[name='s']").val(),
var url = $form.attr("action");
// Send the data using post
var posting = $.post( url, { s: term } )
.done(function(data) {
//Pass the response back to your code
window.external.DoSomething(data);
});
});
我有一个带有 WebBrowser control 的 Winforms 表单。
我已经想出了如何将 C# 代码连接到 Web 浏览器控件中的 Javascript,方法是将 C# class 的实例附加到 ObjectForScripting 属性,像这样:
public partial class Browser : Form
{
private void webBrowser1_DocumentCompleted(object sender, WebBrowserDocumentCompletedEventArgs e)
{
webBrowser1.ObjectForScripting = new ScriptInterface();
}
}
[PermissionSet(SecurityAction.Demand, Name = "FullTrust")]
[ComVisible(true)]
public class ScriptInterface
{
public void DoSomething(string data)
{
// Do something interesting with data here
}
}
...然后从 Javascript 调用它,如下所示:
<button onclick=window.external.DoSomething('with this')/>
我还没有弄清楚如何从 WebBrowser 控件中的表单捕获 POST 操作的结果,并在我的 C# 代码中使用它。
您或许可以使用 jQuery post
代替表格 post。
假设您的表单的 ID 为 myForm
:
$( "#myForm" ).submit(function( event ) {
// Stop form from submitting normally
event.preventDefault();
// Get some values from elements on the page:
var $form = $(this),
var term = $form.find("input[name='s']").val(),
var url = $form.attr("action");
// Send the data using post
var posting = $.post( url, { s: term } )
.done(function(data) {
//Pass the response back to your code
window.external.DoSomething(data);
});
});