Android通过WebView调用 JS 代码

本文介绍如何在Android应用中使用WebView加载本地HTML,并实现JavaScript与原生代码的交互,包括设置WebView参数、调用JS方法及处理JS弹窗。

新建assets文件夹,将html复制到assets目录下

javascript.html

<!DOCTYPE html>
<html>

   <head>
      <meta charset="utf-8">
      <title>Carson_Ho</title>

     <script>
// Android需要调用的方法
   function callJS(){
      alert("Android调用了JS的callJS方法");
   }
</script>

   </head>

</html>

MainActivity.this

package com.example.kanghuwei.xrecylerview;

import android.app.AlertDialog;
import android.content.DialogInterface;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {
    private WebView mWebView;
    private 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) {
                // 通过Handler发送消息
                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;
            }

        });



    }
}

<think>好的,我现在需要解决用户在Android WebView调用uniapp的JavaScript代码的问题。首先,我得回顾一下用户提供的引用内容,看看有没有相关的信息可以利用。 用户引用了四个资料,其中引用[2]提到了Android调用JS的两种方法:loadUrl和evaluateJavascript。引用[4]则涉及uniapp和Android原生的数据交互,提到了继承StandardFeature类。不过用户的问题是如何在Android WebView调用uniapp的JS方法,所以可能需要结合这些方法。 首先,uniapp通常打包成H5应用,所以在WebView中加载的是uniapp生成的页面。调用JS方法和普通H5调用应该类似。根据引用[2],Android可以通过WebViewloadUrl或evaluateJavascript执行JS代码。需要确保WebView设置正确,比如启用JavaScript支持。 然后,考虑uniapp的结构。uniapp的JS方法可能存在于特定的对象或模块中,比如uni对象。例如,uni.postMessage可能是一个方法。所以调用时可能需要通过window对象访问,比如window.uni.postMessage。 另外,引用[4]提到在Android端创建插件类,继承StandardFeature,这可能涉及到原生与uniapp的交互,但用户的问题是从Android调用uniapp的JS,而不是相反。所以重点可能还是在WebView中执行JS代码。 接下来,需要确保WebView正确加载了uniapp的页面,并且JS接口已经配置好。可能需要使用addJavascriptInterface来暴露原生方法给JS,但这里用户需要的是原生调用JS,所以应该使用loadUrl或evaluateJavascript。 可能的步骤: 1. 配置WebView启用JavaScript。 2. 加载uniapp的H5页面。 3. 使用loadUrl("javascript:uni.someMethod()")或evaluateJavascript来调用方法。 需要注意evaluateJavascript是异步的,适合需要返回值的情况。而loadUrl是同步的,但可能在某些情况下需要放在UI线程中执行。 另外,要确保uniapp的方法在全局作用域中可访问,或者通过window对象调用。如果uniapp的方法被封装在某个模块中,可能需要调整调用方式。 潜在的问题:跨域或安全限制,需要检查WebView的设置是否正确,比如是否允许跨域访问。还有,调用时机是否正确,比如在页面加载完成后才执行JS代码,否则可能找不到方法。可以通过WebViewClient的onPageFinished方法来确保页面加载完成后再调用。 总结步骤: - 初始化WebView,启用JS。 - 设置WebViewClient监听页面加载完成。 - 在onPageFinished中使用loadUrl或evaluateJavascript调用uniapp的JS方法。</think>在Android WebView调用uniapp的JavaScript方法可以通过以下步骤实现: ### 一、基础配置流程 1. **启用WebView的JavaScript支持** ```java binding.webView.getSettings().setJavaScriptEnabled(true); ``` 2. **加载uniapp生成的H5页面** ```java binding.webView.loadUrl("https://your-uniapp-h5-domain/index.html"); ``` 3. **确保调用时机在页面加载完成后** ```java binding.webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); // 在此处执行JS调用 } }); ``` ### 二、两种核心调用方式 1. **通过loadUrl调用(同步)** ```java // 调用无返回值方法 binding.webView.post(() -> { binding.webView.loadUrl("javascript:uni.navigateTo({url:'/pages/home'})"); }); // 调用带参数方法 String jsCode = "javascript:uni.request({url:'https://api.com', success: (res)=>{console.log(res)}})"; binding.webView.loadUrl(jsCode); ``` 2. **通过evaluateJavascript调用(异步,推荐)** ```java binding.webView.evaluateJavascript( "(function() { return uni.getSystemInfoSync().platform })();", new ValueCallback<String>() { @Override public void onReceiveValue(String value) { // 返回值处理:value为JSON格式字符串 Log.d("JS_RESULT", "平台信息:" + value); } } ); ``` ### 三、uniapp特殊场景处理 1. **调用Vue组件方法** 需通过`$vm`访问Vue实例: ```java String js = "javascript:document.querySelector('uni-page').__vue__.$vm.yourMethod()"; binding.webView.evaluateJavascript(js, null); ``` 2. **处理uni-app框架事件** 可通过`uni.$emit`/`uni.$on`机制: ```java // Android触发事件 String triggerEvent = "javascript:uni.$emit('nativeEvent', {data: '来自Android的数据'})"; binding.webView.evaluateJavascript(triggerEvent, null); ``` ### 四、调试与异常处理 1. **开启WebView调试模式** ```java if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { WebView.setWebContentsDebuggingEnabled(true); } ``` 2. **常见错误排查** - **方法未找到**:确认方法在`mounted`生命周期后执行 - **跨域问题**:配置`WebSettings.setAllowUniversalAccessFromFileURLs(true)` - **协议头限制**:部分API需在`https`协议下生效
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值