使用C# 的webBrowser寫模擬器時的javascript腳本調用問題
感覺很久不寫模擬器代碼了,昨天調試的時候碰了點壁,記錄下來,避免大家再跟我犯同樣的錯誤。
加入Javascript腳本的地方:
HtmlElement jsElement = webBrowser1.Document.CreateElement("script"); jsElement.SetAttribute("type", "text/javascript"); jsElement.SetAttribute("text", "showMeAction = function(e) { window.alert(e);}"); webBrowser1.Document.Body.AppendChild(jsElement);
調用的地方:
string[] args = new string[1]; args[0] = "Hello element!"; webBrowser1.Document.InvokeScript("showMeAction", args);
大家特別注意的是后面腳本調用的時候,只能出現(xiàn)函數(shù)名與參數(shù)值列表,不能增加其他內容,否則調用就不會成功。
使用的腳本代碼:(這里的腳本代碼模擬了鼠標移動的基礎需求,通過Js直接發(fā)鼠標事件的方式來實現(xiàn)自動機器人)
function createEvent(eventName, ofsx, ofsy) { var evt = document.createEvent('MouseEvents'); evt.initMouseEvent(eventName, true, false, null, 0, 0, 0, ofsx, ofsy, false, false, false, false, 0, null); return evt; } function moveElement(pxToMove) { var sliderKnob = document.getElementsByClassName("gt_slider_knob")[0]; var boxRect = sliderKnob.getBoundingClientRect(); var move = createEvent('mousemove', boxRect.left + sliderKnob.offsetLeft + pxToMove, boxRect.top + sliderKnob.offsetTop); var down = createEvent('mousedown', boxRect.left + sliderKnob.offsetLeft, boxRect.top + sliderKnob.offsetTop); var up = createEvent('mouseup'); sliderKnob.dispatchEvent(down); document.dispatchEvent(move); sliderKnob.dispatchEvent(up); }
以上所述是小編給大家介紹的使用C# 的webBrowser寫模擬器時的javascript腳本調用問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 利用FlubuCore用C#來寫DevOps腳本的方法詳解
- C#調用python腳本的方法步驟(2種)
- 在VS2017中用C#調用python腳本的實現(xiàn)
- 微信跳一跳自動腳本C#代碼實現(xiàn)
- C#調用Python腳本的簡單示例
- 總結ASP.NET C#中經(jīng)常用到的13個JS腳本代碼
- C#創(chuàng)建數(shù)據(jù)庫及導入sql腳本的方法
- C#利用ScriptControl動態(tài)執(zhí)行JS和VBS腳本
- 在C#中調用VBScript、javascript等腳本的實現(xiàn)代碼
- 常用工具之 vb轉化C# 數(shù)據(jù)連接串 正則表達式查詢 源碼世界 腳本字典
- C# 腳本引擎CS-Script的使用
相關文章
一文詳解C#中重寫(override)及覆蓋(new)的區(qū)別
這篇文章主要為大家詳細介紹了C#中重寫(override)及覆蓋(new)這兩個關鍵詞的區(qū)別,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2023-03-03C#使用DateAndTime.DateDiff實現(xiàn)計算年齡
這篇文章主要為大家詳細介紹了C#如何使用DateAndTime.DateDiff實現(xiàn)根據(jù)生日計算年齡,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2024-01-01