转自:原文链接
通过 WebBrowser 可以在页面中执行 js 函数,与取得 js 变量值还是有一定距离,考虑到既然可以获取页面元素,为什么不通过页面元素曲线救国呢?马上行动。
1 用万能的 eval 自定义一个函数,用来完成需要的操作
2 再用 eval 调用定义的函数传入特定的参数:
- public static string htmlid = Guid.NewGuid().ToString();
- private string GetJsVar(WebBrowser webBrowser1, string varname)
- {
- if (webBrowser1.Document == null)
- return "No document";
- webBrowser1.Document.InvokeScript("eval", new[]{ @"
- CreateHiddenInputForReturn = function(id, val) {
- var elm = document.getElementById(id);
- if(elm == null) {
- elm = document.createElement('INPUT');
- elm.id = id;
- elm.type=""HIDDEN"";
- document.body.insertBefore(elm);
- }
- elm.value = eval('typeof('+val.split(/[\[\.]/)[0]+')')=='undefined' ? id : eval(val);
- }
- "});
- webBrowser1.Document.InvokeScript("CreateHiddenInputForReturn", new[] { htmlid, varname });
- HtmlElement obj = webBrowser1.Document.GetElementById(htmlid);
- if (obj != null)
- {
- string val = obj.GetAttribute("value");
- if (val == htmlid)
- return "no js var";
- return val;
- }
- return "null";
- }