cefSharp通過js操控頁面,含跨域操控


基本操控

cefSharp可以讓頁面運行指定的js代碼,所以這就為操控頁面提供了方法,js能做的所有操控DOM元素的方法,cefSharp都可以做了
在67版本中對頁面使用js的方法很簡單,一句話:

browser.ExecuteJavaScriptAsync(script);//script是String格式的js代碼

    1

##獲取Js返回的結果

如果要獲取到js返回的結果,則需要麻煩一點

 String script =
            @"(function() {
                var tags = document.getElementsByTagName('span');
                var result=false;
                for(var i in tags){
                    if (tags[i].nodeType == 1){
                        if (tags[i].getAttribute('class') == 'example'){
                            result=true;
                        }
                    }
                }
                return result;
             })()";

browser.EvaluateScriptAsync(script).ContinueWith(x =>
{
    var response = x.Result;

    if (response.Success && response.Result != null)
    {
        bool result = (bool)response.Result;
        if (result)
        {
            //TODO
        }
        else
        {
           //TODO
        }
    }
});



注意:花括號中間的代碼是異步執行的
上面的例子的作用是在在頁面中尋找一個class為example的span元素,找到返回true,找不到返回false;
跨域操控

跨域操控的方式很簡單,讀取browser里面有幾個框架,在框架下面執行指定JS代碼就好了

List<long> idList = browser.GetBrowser().GetFrameIdentifiers();//idList里面裝了頁面所有iframe的數據
//取出第2個iframe
IFrame frame = browser.GetBrowser().GetFrame(idList[2]);
//執行js代碼
frame.ExecuteJavaScriptAsync(script);



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM