js交互 webiview点击事件获取android的方法

本文介绍了一个简单的JS与Android跨平台交互示例,通过WebView实现了JavaScript调用Android本地方法的功能,展示了如何进行扫码和消息传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<script>
 function scanGoods(){
  
 var goodsSn = window.webkit.messageHandlers.scanGoods.postMessage(null);
  
 }function scanGoods2(){
  
 var goodsSn = window.contact.toast('123')
 alert(goodsSn)
 }
 function getIosScanCode(arg){
 alert(arg)
 }
 </script>
上图是js里面的代码。


android的代码

  //加载页面
        webView = (WebView) findViewById(R.id.webview);
        //允许JavaScript执行
        webView.getSettings().setJavaScriptEnabled(true);

  webView.loadUrl("地址");

    // 添加一个对象, 让JS可以访问该对象的方法, 该对象中可以调用JS中的方法
        webView.addJavascriptInterface(new Contact1(), "contact");//contact 对应h5标注红色的contact


//给h5提供 的方法

 private final class Contact1 {
   
      //toast 对应 蓝色字体的toast
        @JavascriptInterface
        public void toast(String str){
       
       
        Toast.makeText(MainActivity.this, str
, Toast.LENGTH_LONG).show();

        }


    }

如果要启动别的activity,

   @JavascriptInterface
        public void toast(String str){
        new Handler().post(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
// startActivity(new Intent(MainActivity.this,CaptureActivity.class));
}
});



很简单的几句代码就能轻松的实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值