WebView載入本地Html檔案並實現點擊效果

來源:互聯網
上載者:User

標籤:yqi   設定   這一   控制項   extend   java   toast   post   setting   

Webview是用來與前端互動的紐,可以載入本地Html檔案,和網頁並實現互動的功能。

WebView通過WebSetting可以使用Android原生的JavascriptInterface來進行js和java的通訊。

載入本地檔案:webView.loadUrl("file:///android_asset/xxx.html");

載入網頁:webView.loadUrl("http://baidu.com");

案例:(WebView載入本地Html並實現與JS通訊) :

       

       

代碼:

/*** *  * WebView載入本地檔案和實現JS點擊效果 *  * @author zq * */public class MainActivity extends Activity {    private WebView webView;    @Override    protected void onCreate(Bundle savedInstanceState) {        // TODO Auto-generated method stub        super.onCreate(savedInstanceState);          setContentView(R.layout.activity_main);          initView();        }    private void initView() {        // TODO Auto-generated method stub          // 擷取webview控制項            webView = (WebView) findViewById(R.id.activity_webview);            // 擷取WebView的設定            WebSettings webSettings = webView.getSettings();            // 將JavaScript設定為可用,這一句話是必須的,不然所做一切都是徒勞的            webSettings.setJavaScriptEnabled(true);            // 給webview添加JavaScript介面            webView.addJavascriptInterface(new JsInterface(), "control");            // 通過webview載入html頁面            webView.loadUrl("file:///android_asset/l.html");    }    public class JsInterface {        @JavascriptInterface        public void showToast(String toast) {            Toast.makeText(MainActivity.this, toast, Toast.LENGTH_SHORT).show();        }        public void log(final String msg) {            webView.post(new Runnable() {                @Override                public void run() {                    webView.loadUrl("javascript log(" + "‘" + msg + "‘" + ")");                }            });        }    }}

JS檔案

 function showToast(toast) {           javascript:control.showToast(toast);        }  function log(msg) {        consolse.log(msg);    }

AndroidManifest.xml 中加許可權

<uses-permission android:name="android.permission.INTERNET"/><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>  

代碼未完全給出,要源碼直接下載即可

 

源碼下載:http://download.csdn.net/detail/dickyqie/9710928

 

WebView載入本地Html檔案並實現點擊效果

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.