WebView加载html并修改页面内容,及获取Html源码

最近一个项目中有Android与js交互,中途js跑路了,一些小的功能就要Android完成了,webview加载html展示的时候,有的时候html页面上的一些内容需要做一些调整,高高手一般都会编辑一些js脚本人后注入到页面进行操作修改,,

可惜我不在哪个范畴内,就只能自己捣鼓捣鼓了,下面是修改html页面中的button大小

cssCode =
        "input[id=\"btnAttachAdd\"]{\n"
                + "font-size:30px;margin:15px;height:50px"
                + "}\n"
                + "input[id=\"btnSave\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnPrint\"]{ display:none}"
                + "input[id=\"btnFlowDes\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnHistory\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnSendBack\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnCirculate\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnCirculateComplate\"]{ font-size:30px;margin:15px;height:50px}"
                + "input[id=\"btnSend\"]{ font-size:30px;margin:15px;height:50px}"
                + "div[class=\"modtitle_text dialogtitle\"]{font-size:20px}"
                + "div[class=\"tbf\"]{width:95%}"
                + "table[class=\"t_tbl\"]{font-size:25px;width:100%}";
byte[] buffer = cssCode.getBytes();
cssCode = Base64.encodeToString(buffer, Base64.NO_WRAP);
view.loadUrl("javascript:(function() {"
        + "var parent = document.getElementsByTagName('head').item(0);"
        + "var style = document.createElement('style');"
        + "style.type = 'text/css';" + "style.innerHTML = window.atob('"
        + cssCode + "');" + "parent.appendChild(style)" + "})();");

这个样子的;

 

还有一些呢,需要我们获取到Html的源码,然后怎么获取到源码呢?

看这了:

先是一些必要的设置

webView.getSettings().setJavaScriptEnabled(true);
webView.addJavascriptInterface(new InJavaScriptLocalObj(), "java_obj");
webView.setWebViewClient(new WebViewClient());

这些大家都知道,就不解释了,接下来

webView.setWebViewClient(new WebViewClient(){

    @Override
    public void onPageFinished(WebView view, String url) {
        view.loadUrl("javascript:window.java_obj.getSource(''+" +
                "document.getElementsByTagName('html')[0].innerHTML+'');");
        super.onPageFinished(view, url);
    }
});

然后接口实现一下就玩完了

final class InJavaScriptLocalObj {
    @JavascriptInterface
    public void getSource(String html) {
        Log.d("html=", html);
    }
}

哦哦哦,对了,上面加上

webView.loadUrl("写入你需要获取源码的HTML");

注意:权限

鉴于这个世界还是懒人居多,那么小弟在此奉上一个获取html源码完美运行的demo地址:https://download.csdn.net/download/m5157/11127783

 

你可能感兴趣的:(WebView)