Webview和JS交互方式

前言

  • 现在很多App里都内置了Web网页(Hybrid App),比如说很多电商平台,淘宝,京东等等
webview_and_JS.png

1. 交互方式总结

Android与JS通过Webview互相调用方法,

  • android去调用JS的代码
  • JS去调用Android的代码

两者沟通的桥梁是WebView

对于Android调用JS代码的方法有2种:

  1. 通过WebView的loadUrl()
  2. 通过WebView的evaluateJavascript()

对于JS调用Android代码方法有3种:

  1. 通过WebView的addJavascriptInterface()进行对象映射
  2. 通过 WebViewClient 的shouldOverrideUrlLoading ()方法回调拦截 url
  3. 通过 WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt()方法回调拦截JS对话框alert()、confirm()、prompt() 消息

2. 交互方式

对于Android调用JS代码的方法有2种:

  1. 通过WebView的loadUrl()
  2. 通过WebView的evaluateJavascript()
    方式1:通过WebView的loadUrl()
  • 实例介绍:点击Android按钮,即调用WebView JS(文本名为javascript)中callJS()
步骤1:将需要调用的JS代码以.html格式放到src/main/assets文件夹里

1.为了方便展示,本文是采用Andorid调用本地JS代码说明;
2.实际情况时,Android更多的是调用远程JS代码,即将加载的JS代码路径改成url即可

需要加载JS代码:javascript.html

// 文本名:javascript               Carson_Ho// JS代码        
步骤2:在Android里通过WebView设置调用JS代码
 public class MainActivity extends AppCompatActivity {    WebView mWebView;    Button button;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        mWebView =(WebView) findViewById(R.id.webview);        WebSettings webSettings = mWebView.getSettings();        // 设置与Js交互的权限        webSettings.setJavaScriptEnabled(true);        // 设置允许JS弹窗        webSettings.setJavaScriptCanOpenWindowsAutomatically(true);        // 先载入JS代码        // 格式规定为:file:///android_asset/文件名.html        mWebView.loadUrl("file:///android_asset/javascript.html");        button = (Button) findViewById(R.id.button);        button.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                // 必须另开线程进行JS方法调用(否则无法调用)                mWebView.post(new Runnable() {                    @Override                    public void run() {                        // 注意调用的JS方法名要对应上                        // 调用javascript的callJS()方法                        mWebView.loadUrl("javascript:callJS()");                    }                });            }        });        // 由于设置了弹窗检验调用结果,所以需要支持js对话框        // webview只是载体,内容的渲染需要使用webviewChromClient类去实现        // 通过设置WebChromeClient对象处理JavaScript的对话框        //设置响应js 的Alert()函数        mWebView.setWebChromeClient(new WebChromeClient() {            @Override            public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {                AlertDialog.Builder b = new AlertDialog.Builder(MainActivity.this);                b.setTitle("Alert");                b.setMessage(message);                b.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {                    @Override                    public void onClick(DialogInterface dialog, int which) {                        result.confirm();                    }                });                b.setCancelable(false);                b.create().show();                return true;            }        });    }}

方式2:通过WebView的evaluateJavascript()

 mWebView.evaluateJavascript("javascript:callJS()", new ValueCallback() {        @Override        public void onReceiveValue(String value) {            //此处为 js 返回的结果        }    });}

更多相关文章

  1. Java - android中的枚举类型(Enum)
  2. Android应用开发提高系列(5)――Android动态加载(下)――加载已安装A
  3. Android(安卓)UI加速
  4. android简单实例-----------------使用SQLiteOpenHelper以及SQLi
  5. Android中Service组件详解
  6. android访问远程数据库
  7. Android与H5交互框架实践(下)
  8. 浅谈Java中Collections.sort对List排序的两种方法
  9. Python list sort方法的具体使用

随机推荐

  1. Android系统和linux内核的关系详解
  2. AndroidMediaRecorder架构详解
  3. android 源代码获取
  4. android开发图片小技巧
  5. Android 2.3 Gallery3D添加gif支持——概
  6. Android_ViewPager实现滚动广告
  7. Android(安卓)语音识别
  8. Android pull解析XML数据
  9. Android中的广播机制
  10. android开发1:安卓开发环境搭建(eclipse+j