JS调用Android方法示例

前言

目前很多App里都内置了Web网页(Hybrid App),这就涉及到Android客户端与Web网页交互的实现,接下来通过示例说明JS如何调用Android方法。

示例代码

AndroidManifest.xml

AndroidManifest.xml需要加入INTERNET权限:

<uses-permission android:name="android.permission.INTERNET" />

AndroidtoJs.java

定义一个与JS对象映射关系的Android类:AndroidtoJs,AndroidtoJs中被JS调用的方法必须加入@JavascriptInterface注解
在这里插入图片描述

package com.example.testjs2;

import android.webkit.JavascriptInterface;

public class AndroidtoJs {
    private String status = "off";

	//打印信息方法
    @JavascriptInterface
    public void print(String msg) {
        System.out.println(msg);
    }

	//获取状态值方法
    @JavascriptInterface
    public String getStatus() {
        return status;
    }

	//修改状态值方法
    @JavascriptInterface
    public void setStatus(String status) {
        this.status = status;
    }
}

activity_main.xml

在activity_main.xml添加一个WebView即可,这里将id设为webView1。

MainActivity.java

在MainActivity.java为webView设置与JS交互的权限,并通过将addJavascriptInterface()将Java对象映射到JS对象,最后加载javascript.html(在下一步创建):

package com.example.testjs2;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;

public class MainActivity extends AppCompatActivity {

    WebView webView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        webView = (WebView) findViewById(R.id.webView1);
        WebSettings webSettings = webView.getSettings();

        // 设置与Js交互的权限
        webSettings.setJavaScriptEnabled(true);

        // 通过addJavascriptInterface()将Java对象映射到JS对象
        //参数1:Javascript对象名
        //参数2:Java对象名
        webView.addJavascriptInterface(new AndroidtoJs(), "test");//AndroidtoJS类对象映射到js的test对象
        webView.loadUrl("file:///android_asset/javascript.html");
    }
}

javascript.html

创建assets目录,并在assets目录下添加JS文件,这里命名为javascript.html,在javascript.html里通过test对象调用Android方法:
在这里插入图片描述

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>Carson</title>
      <script>
         function turnOn() {
            test.setStatus("On");
         }
         function turnOff() {
            test.setStatus("Off");
         }
         function getStatus(){
            let status = "";
            status = test.getStatus();
            test.print("Status:"+status);
         }
      </script>
   </head>
   <body>
      <br /><br /><br /><br /><br /><br />
      <button onClick="turnOn()">打开</button>
      <br /><br /><br /><br /><br /><br />
      <button onClick="turnOff()">关闭</button>
      <br /><br /><br /><br /><br /><br />
      <button onClick="getStatus()">点击查看状态</button>
   </body>
</html>

测试

在真机或模拟器上运行app,反复点击三个按钮,查看logcat的打印是否正确:
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值