WebView中js调用java

记录下,等会在加上一个js传多个参数的代码。代码很简单,是调用QR扫描器的一个事件。


<li><a id="guide" href="javascript:window.oa_main.qr_scan()">
<img src="./img/iLeopauR.png" alt="Guide" height="72" width="72" />
<span>二维码扫描</span>
</a></li>



public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.main);
// this.initContacts();
web = (WebView) this.findViewById(R.id.web);
web.getSettings().setAllowFileAccess(true);
this.web.getSettings().setSupportZoom(false);
this.web.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
this.web.setScrollBarStyle(SCROLLBARS_OUTSIDE_OVERLAY);
web.getSettings().setJavaScriptEnabled(true);

// web.setWebChromeClient(new MyWebChromeClient());
web.addJavascriptInterface(new MyJavaScriptInterface(), "oa_main"); // 定义oa_main,为OA面板使用

//web.addJavascriptInterface(new OaSystemInterface(), "oa_sys"); //注册和登录js接口
web.loadUrl("file:///android_asset/index.html");
super.onStart();
}
final class MyJavaScriptInterface {
MyJavaScriptInterface(){}
public void qr_scan() {
Intent intent = new Intent("com.google.zxing.client.android.SCAN_bluehood");
startActivityForResult(intent,BARCODE);
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的示例代码,演示如何在 AndroidWebView 使用 JavaScript 调用 Java 方法: 1. 首先,在 Java 定义一个类,包含一个供 JavaScript 调用的方法: ```java public class JavaScriptInterface { private Context context; public JavaScriptInterface(Context context) { this.context = context; } @JavascriptInterface public void showToast(String message) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); } } ``` 在这个类,我们定义了一个名为 `showToast` 的方法,用于在 Android 应用显示一条 Toast 消息。 2. 接下来,在 Activity 创建一个 WebView 实例,并将 JavaScript 接口对象传递给它: ```java WebView webView = findViewById(R.id.webview); webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new JavaScriptInterface(this), "Android"); ``` 在这个代码,我们首先启用 WebViewJavaScript 功能,然后创建了一个 `JavaScriptInterface` 对象,并将其注册到 WebView 。我们还将这个接口对象命名为 `Android`,以后在 JavaScript 使用这个名称来调用它。 3. 最后,在 HTML 编写 JavaScript 代码,调用 Android 接口的方法: ```html <button onclick="showToast('Hello, Android!')">Show Toast</button> <script> function showToast(message) { Android.showToast(message); } </script> ``` 在这个代码,我们定义了一个按钮,当用户点击它时,将调用 `showToast` 方法。在 JavaScript ,我们使用 `Android.showToast` 来调用 Android 接口的方法。 这就是一个简单的示例,演示了如何在 AndroidWebView 使用 JavaScript 调用 Java 方法。需要注意的是,这个方法需要在 Android 4.2 及以上版本才能使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值