android js webview 交互

public class MainActivity extends AppCompatActivity {
    WebView mWebView;
    @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);
        mWebView.addJavascriptInterface(this, "app");//对应js中的app.xxx
        // 先载入JS代码
        mWebView.loadUrl("http://www.more-print.com/api/dealer/index");
        mWebView.setWebViewClient(new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });

    }
    @JavascriptInterface
    public void scan(String msg){
        //对应js中xxx.scan("")

        Toast.makeText(this,msg,Toast.LENGTH_LONG).show();
        //
        mWebView.post(new Runnable() {
            @Override
            public void run() {

                // 注意调用的JS方法名要对应上
                // 调用javascript的callJS()方法
                mWebView.loadUrl("javascript:scanQRCallBack("+"20171205"+")");
            }
        });

    }

}

export default {
		data() {
			return {
			 
			}
		},
		// 将vue组件的要回调的函数暴露出去
		mounted:function(){
		            
				 
		                // 将subscanQRCallBack方法绑定到window下面,提供给外部调用
		                window.scanQRCallBack =  this.subscanQRCallBack
		                 
		     
		        },
		
	 
		methods: {
			scan(){
			    // alert('开始扫码了')
			 
			    window.app.scan('OS与js交互')  // 通过window调用app提供的client对象
			},
					
			subscanQRCallBack(result){
			   alert('扫码结果:'+result); 
			},
		}
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值