C#WinForm WebBrowser (二) 實用方法總結

 實用方法1:獲取狀態欄信息html

void webBrowser1_StatusTextChanged(object sender, EventArgs e)
{
label1.Text = webBrowser1.StatusText;
}
實用方法2:頁面跳轉後改變地址欄地址
//在Navigated事件處理函數中改變地址欄地址是最恰當的:
private void webBrowser1_Navigated(object sender, WebBrowserNavigatedEventArgs e)
{
textBox1.Text = webBrowser1.Url.ToString();
}
實用方法3:設置單選框
//建議使用執行單擊事件的方式來設置單選框,而不是修改屬性:
webBrowser1.Document.GetElementById("RBT_A").InvokeMember("click");
實用方法4:設置聯動型下拉列表
複製代碼
//比較常見的聯動型多級下拉列表就是省/市縣選擇了,這種狀況下直接設置選擇項的屬性不會觸發聯動,須要在最後執行觸發事件函數才能正常工做:

foreach (HtmlElement f in s.GetElementsByTagName("option"))
{
if (f.InnerText == "北京")
{
f.SetAttribute("selected", "selected");
}
else
{
f.SetAttribute("selected", "");
}
}
s.RaiseEvent("onchange");
複製代碼
 
 
 
 
實用方法一:在WinForm中相應Web事件
假設HTML源代碼以下:
<html> 
<body>
<input type="button" id="btnClose" value="關閉" />
</body>
</html>
複製代碼
    
    
    
    
HtmlDocument htmlDoc = webBrowser.Document;
HtmlElement btnElement = htmlDoc.All[ " btnClose "];
if (btnElement != null)
{
btnElement.click += new HtmlElementEventHandler(HtmlBtnClose_Click);
}

//很簡單吧?那麼稍稍高級一點的——咱們都知道一個HTML元素可能有不少各類各樣的事件,而HtmlElement這個類只給出最經常使用、共通的幾個。那麼,如何響應其餘事件呢?這也很簡單,只須要調用HtmlElement的AttachEventHandler就能夠了:
btnElement.AttachEventHandler(" new EventHandler(HtmlBtnClose_Click));
//這一句等價於上面的btnElement.click += new HtmlElementEventHandler(HtmlBtnClose_Click);
複製代碼
 

對於其餘事件,把"onclick"換成該事件的名字就能夠了。例如:web

formElement.AttachEventHandler("onsubmit", new EventHandler(HtmlForm_Submit)); 

 

實用方法二:模擬表單自動填寫和提交
假設有一個最簡單的登陸頁面,輸入用戶名密碼,點「登陸」按鈕便可登陸。已知用戶名輸入框的id(或Name,下同)是username,密碼輸入框的id是password,「登陸」按鈕的id是submitbutton,那麼咱們只須要在webBrowser的DocumentCompleted事件中使用下面的代碼便可:
複製代碼
HtmlElement btnSubmit = webBrowser.Document.All["submitbutton"]; 
HtmlElement tbUserid = webBrowser.Document.All["username"];
HtmlElement tbPasswd = webBrowser.Document.All["password"];

if (tbUserid == null || tbPasswd == null || btnSubmit == null)
return;

tbUserid.SetAttribute("value", "smalldust");
tbPasswd.SetAttribute("value", "12345678");

btnSubmit.InvokeMember("click");
複製代碼

關於表單的提交,的確還有另外一種方法就是獲取form元素而不是button,並用form元素的submit方法:ide

HtmlElement formLogin = webBrowser.Document.Forms["loginForm"];  
//……
formLogin.InvokeMember("submit");

本文之因此沒有推薦這種方法,是由於如今的網頁,不少都在submit按鈕上添加onclick事件,以對提交的內容作最基本的驗證。若是直接使用form的submit方法,這些驗證代碼就得不到執行,有可能會引發錯誤。函數

實用方法三:調用腳本

首先是調用Web頁面的腳本中已經定義好的函數。假設HTML中有以下Javascript:this

function DoAdd(a, b) {
return a + b;
}

那麼,咱們要在WinForm調用它,只需以下代碼便可:spa

object oSum = webBrowser.Document.InvokeScript("DoAdd", new object[] { 1, 2 });
int sum = Convert.ToInt32(oSum);

其次,若是咱們想執行一段Web頁面中本來沒有的腳本,該怎麼作呢?此次.Net的類沒有提供,看來還要依靠COM了。IHTMLWindow2能夠將任意的字符串做爲腳本代碼來執行。debug

複製代碼
string scriptline01 = @"function ShowPageInfo() {";
string scriptline02 = @" var numLinks = document.links.length; ";
string scriptline03 = @" var numForms = document.forms.length; ";
string scriptline04 = @" var numImages = document.p_w_picpaths.length; ";
string scriptline05 = @" var numScripts = document.scripts.length; ";
string scriptline06 = @" alert('網頁的統計結果:\r\n連接數:' + numLinks + ";
string scriptline07 = @" '\r\n表單數:' + numForms + ";
string scriptline08 = @" '\r\n圖像數:' + numImages + ";
string scriptline09 = @" '\r\n腳本數:' + numScripts);}";
string scriptline10 = @"ShowPageInfo();";

string strScript = scriptline01 + scriptline02 + scriptline03 + scriptline04 + scriptline05 +
scriptline06 + scriptline07 + scriptline08 + scriptline09 + scriptline10;

IHTMLWindow2 win = (IHTMLWindow2)webBrowser.Document.Window.DomWindow;
win.execScript(strScript, "Javascript");
複製代碼
 

最後:在腳本中調用WinForm裏的代碼,這個可能嗎? 呵呵,固然是可能的。
下面的代碼示例演示如何使用 ObjectForScripting 屬性。在該示例中,ObjectForScripting 屬性被設置爲當前窗體。code

 

   
   
   
   
  1. using System; 
  2. using System.Windows.Forms; 
  3. using System.Security.Permissions; 
  4. [PermissionSet(SecurityAction.Demand, Name="FullTrust")] 
  5. [System.Runtime.InteropServices.ComVisibleAttribute(true)] 
  6. public class Form1 : Form 
  7. private WebBrowser webBrowser1 = new WebBrowser(); 
  8. private Button button1 = new Button(); 
  9. [STAThread] 
  10. public static void Main() 
  11. Application.EnableVisualStyles(); 
  12. Application.Run(new Form1()); 
  13. public Form1() 
  14. button1.Text = "call script code from client code"
  15. button1.Dock = DockStyle.Top; 
  16. button1.Click += new EventHandler(button1_Click); 
  17. webBrowser1.Dock = DockStyle.Fill; 
  18. Controls.Add(webBrowser1); 
  19. Controls.Add(button1); 
  20. Load += new EventHandler(Form1_Load); 
  21. private void Form1_Load(object sender, EventArgs e) 
  22. webBrowser1.AllowWebBrowserDrop = false
  23. webBrowser1.IsWebBrowserContextMenuEnabled = false
  24. webBrowser1.WebBrowserShortcutsEnabled = false
  25. webBrowser1.ObjectForScripting = this
  26. // Uncomment the following line when you are finished debugging. 
  27. //webBrowser1.ScriptErrorsSuppressed = true; 
  28. webBrowser1.DocumentText = 
  29. "<html><head><script>" + 
  30. "function test(message) { alert(message); }" + 
  31. "</script></head><body><button " + 
  32. "onclick=\"window.external.Test('called from script code')\">" + 
  33. "call client code from script code</button>" + 
  34. "</body></html>"
  35. public void Test(String message) 
  36. MessageBox.Show(message, "client code"); 
  37. private void button1_Click(object sender, EventArgs e) 
  38. webBrowser1.Document.InvokeScript("test"
  39. new String[] { "called from client code" }); 
 

http://www.cnblogs.com/08shiyan/archive/2011/04/22/2023861.htmlorm

相關文章
相關標籤/搜索