Android WebView簡單應用

來源:互聯網
上載者:User

Android WebView簡單應用

WebView是View的一個子類,可以讓你在activity中顯示網頁。在布局中拉入一個WebView,一個Button,一個EditText
布局代碼如下:

            

源碼代碼如下:

package com.shendan.webrowser;import android.support.v7.app.ActionBarActivity;import android.os.Bundle;import android.view.KeyEvent;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.webkit.WebSettings;import android.webkit.WebView;import android.webkit.WebViewClient;import android.widget.Button;import android.widget.EditText;public class MainActivity extends ActionBarActivity {    EditText editText;    Button button;    WebView webView;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        editText = (EditText)findViewById(R.id.editText1);        editText.setText("http://www.baidu.com");        button = (Button)findViewById( R.id.button1);        webView = (WebView)findViewById(R.id.webView1);        WebSettings webSettings = webView.getSettings();        webSettings.setJavaScriptEnabled(true);        webSettings.setDomStorageEnabled(true);        //點擊頁面內串連直接開啟        webView.setWebViewClient(new WebViewClient(){                   public boolean shouldOverrideUrlLoading(WebView view, String url) {                       view.loadUrl(url);                       return true;                   }               });        button.setOnClickListener( new View.OnClickListener() {                     @Override            public void onClick(View v) {                // TODO Auto-generated method stub                String urlstr = editText.getText().toString();                webView.loadUrl(urlstr);            }        });    }    //點擊後退按鈕返回前面的網頁    public boolean onKeyDown(int keyCode,KeyEvent event)    {        if ((keyCode == KeyEvent.KEYCODE_BACK) && webView.canGoBack()) {                   webView.goBack();                   return true;               }               return super.onKeyDown(keyCode, event);    }    @Override    public boolean onCreateOptionsMenu(Menu menu) {        // Inflate the menu; this adds items to the action bar if it is present.        getMenuInflater().inflate(R.menu.main, menu);        return true;    }    @Override    public boolean onOptionsItemSelected(MenuItem item) {        // Handle action bar item clicks here. The action bar will        // automatically handle clicks on the Home/Up button, so long        // as you specify a parent activity in AndroidManifest.xml.        int id = item.getItemId();        if (id == R.id.action_settings) {            return true;        }        return super.onOptionsItemSelected(item);    }}

有幾個注意點:
1、網址一定要包括http://,
2、要增加網路許可權

這樣就可以簡單進行網頁瀏覽了。

webview的API的合理調用,就可以實現比較完整的瀏覽器功能
比如開啟頁面:

myWebView.loadUrl("http://www.google.com");myWebView.loadUrl("file:///android_asset/XX.html");//HTML檔案事先儲存到asset檔案夾。String htmlString = "Title

This is HTML text
Formatted in italics
Anothor Line

";// 載入這個html頁面。myWebView.loadData(htmlString, "text/html", "utf-8");//假如有中文,使用.myWebView.loadDataWithBaseURL(null,htmlString, "text/html", "utf-8",null);

當你的WebView覆寫了URL載入的行為,它會自動地對訪問過的網頁積累一個曆史,你可以利用 goBack() 和 goForward()方法在這個曆史中前進或後退。

通過重寫WebViewClient,可以更好地控制頁面內的行為。

    public class MyWebViewClient extends WebViewClient    {        @Override        public void onPageFinished(WebView view, String url) {            // TODO Auto-generated method stub            super.onPageFinished(view, url);        }        @Override        public void onPageStarted(WebView view, String url, Bitmap favicon) {            // TODO Auto-generated method stub            super.onPageStarted(view, url, favicon);        }        @Override        public void onScaleChanged(WebView view, float oldScale, float newScale) {            // TODO Auto-generated method stub            super.onScaleChanged(view, oldScale, newScale);        }        @Override        public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {            // TODO Auto-generated method stub            return super.shouldOverrideKeyEvent(view, event);        }        @Override        public boolean shouldOverrideUrlLoading(WebView view, String url) {            // TODO Auto-generated method stub            return super.shouldOverrideUrlLoading(view, url);        }    }

接下來講一點比較重要的,就是Webview與js互動。

1.android中利用webview調用網頁上的js代碼。

將webview控制項的支援js的屬性設定為true,然後通過loadUrl就可以直接進行調用,如下所示:

mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.loadUrl(“javascript:test()”);

2.網頁上調用android中java代碼的方法

在網頁中調用java代碼,需要在webview控制項中添加javascriptInterface。如下所示:

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.