全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解 WebView 与 JS 交互传值问题

随着混合开发模式比较流行,很多时候,我们需要在原生的基础上,使用 WebView 加载网页,这样控制更加方便。今天我们来看看,如何将 Java 对象 和 List 集合传值给 JS 调用。

如何将 Java 对象实例传值给 JS

其实将我们在 Android 原生中将 Java 对象实例传值给 JS 承认并且可以使用的对象,方法非常简单。我们来举个例子。

html 文件

我们在本地写了一个 html 文件,放在 assets 目录中。

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>测试</title>
  <h1 id="name" ></h1>
  <h1 id="age"></h1>
  <h1 id="sex"></h1>
  <script>
  // Android需要调用的方法
  function callJS(){
   document.getElementById("age").innerHTML=person.getAge();
   document.getElementById("name").innerHTML=person.getName();
   document.getElementById("sex").innerHTML=person.getSex();
  }
  </script>
</head>
</html>

看到 callJS() 函数中的 person 了吗?它就是我们传值进行的 Java 对象实例。直接就可以使用,获取了年龄,名字,和性别属性。那我们该如何声明该对象,才会被 JS 所承认呢?

Java 对象

来,看看,我们是如何创建 Person 这个实体类的。代码如下:

package com.loonggg.wedswebview;

import android.webkit.JavascriptInterface;

/**
 * Created by loonggg on 2017/5/11.
 */
public class Person {
  private String name;
  private String age;
  private String sex;

  @JavascriptInterface
  public String getAge() {
    return age;
  }

  public void setAge(String age) {
    this.age = age;
  }

  public void setSex(String sex) {
    this.sex = sex;
  }

  @JavascriptInterface
  public String getSex() {
    return sex;
  }

  @JavascriptInterface
  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

}

看到我们实体类 Person 中每个get方法的上面有一个 @JavascriptInterface 的注解了吗?它的意思就是告诉 JS ,这个可以用,所以我们在 Html 文件中,使用 person.get()对应的方法,可以获取到内容。

在 WebView 上是这样传值的:

webView.loadUrl("file:///android_asset/test_object.html");
final Person p = new Person();
p.setName("loonggg");
p.setAge("28");
p.setSex("男");

wv.addJavascriptInterface(p, "person");

wv.loadUrl("javascript:callJS()");

wv.addJavascriptInterface(p, “person”); 的意思就是注入 Java 对象 p 给 webview 为 person,在 JS 调用的时候,对应的就是 person 。

wv.loadUrl(“JavaScript:callJS()”);这句话的意思就是:调用JS中的方法 callJS()函数方法。

Java List如何传给 JS 呢?

其实按道理来说,是不可以将List集合直接传值给 JS 使用,但是既然对象可以传值,JS 可以调用 java 对象,也可以调用 Android 中的方法,那我们就一拆分的形式传过去。

Html 文件

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>测试</title>
  <h1 id="name" ></h1>
  <h1 id="age"></h1>
  <h1 id="sex"></h1>

  <h1>List传值测试</h1>
  <h1 id="name1" ></h1>
  <h1 id="age1"></h1>
  <h1 id="sex1"></h1>
  <script>
  // Android需要调用的方法
  function callJS(){
   document.getElementById("age").innerHTML=person.getAge();
   document.getElementById("name").innerHTML=person.getName();
   document.getElementById("sex").innerHTML=person.getSex();
  }

  function callListJS(){
   document.getElementById("age1").innerHTML=window.javatojs.getPersonObject(0).getAge();
   document.getElementById("name1").innerHTML=window.javatojs.getPersonObject(0).getName();
   document.getElementById("sex1").innerHTML=window.javatojs.getPersonObject(0).getSex()
  }
  </script>
</head>
</html>

拆分传值

如何拆分呢?就是在JS中调用 Android中的方法,里面可以按照索引返回集合中的对象,然后再获取对象中的属性。代码如下:

 /**
   * 该方法将在js脚本中,通过window.javatojs.....()进行调用
   *
   * @return
   */
  @JavascriptInterface
  public Person getPersonObject(int index) {
    return list.get(index);
  }

  @JavascriptInterface
  public int getSize() {
    return list.size();
  }


   list.add(p);
   wv.addJavascriptInterface(this, "javatojs");

   wv.loadUrl("javascript:callListJS()");

整个Acitvity中所有的代码

public class MainActivity extends AppCompatActivity {
  private WebView wv;
  private List<Person> list = new ArrayList<Person>();

  @SuppressLint("JavascriptInterface")
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    wv = new WebView(this);
    setContentView(wv);
    WebSettings ws = wv.getSettings();
    ws.setJavaScriptEnabled(true);
    ws.setUseWideViewPort(true);//适应分辨率
    ws.setLoadWithOverviewMode(true);

    wv.loadUrl("file:///android_asset/test_object.html");
    final Person p = new Person();
    p.setName("loonggg");
    p.setAge("28");
    p.setSex("男");
    wv.addJavascriptInterface(p, "person");

    list.add(p);
    wv.addJavascriptInterface(this, "javatojs");

    wv.setWebViewClient(new WebViewClient() {
      @Override
      public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
        wv.loadUrl("javascript:callJS()");
        wv.loadUrl("javascript:callListJS()");
      }
    });
  }

  /**
   * 该方法将在js脚本中,通过window.javatojs.....()进行调用
   *
   * @return
   */
  @JavascriptInterface
  public Person getPersonObject(int index) {
    return list.get(index);
  }

  @JavascriptInterface
  public int getSize() {
    return list.size();
  }

}

效果图

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# WebView  #   # JS  # 交互传值  # Android 


相关文章: 齐河建站公司:营销型网站建设与SEO优化双核驱动策略  建站之星CMS五站合一模板配置与SEO优化指南  如何安全更换建站之星模板并保留数据?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  如何高效生成建站之星成品网站源码?  如何快速选择适合个人网站的云服务器配置?  高端建站三要素:定制模板、企业官网与响应式设计优化  高防服务器租用首荐平台,企业级优惠套餐快速部署  如何选择最佳自助建站系统?快速指南解析优劣  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  学校为何禁止电信移动建设网站?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  网页设计与网站制作内容,怎样注册网站?  怀化网站制作公司,怀化新生儿上户网上办理流程?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  济南专业网站制作公司,济南信息工程学校怎么样?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  太原网站制作公司有哪些,网约车营运证查询官网?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  临沂网站制作公司有哪些,临沂第四中学官网?  贸易公司网站制作流程,出口贸易网站设计怎么做?  建站主机选购指南:核心配置优化与品牌推荐方案  如何在橙子建站中快速调整背景颜色?  全景视频制作网站有哪些,全景图怎么做成网页?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  一键网站制作软件,义乌购一件代发流程?  如何快速建站并高效导出源代码?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  建站上市公司网站建设方案与SEO优化服务定制指南  如何快速搭建高效WAP手机网站?  如何快速搭建自助建站会员专属系统?  如何在Tomcat中配置并部署网站项目?  网站制作免费,什么网站能看正片电影?  如何彻底卸载建站之星软件?  如何选择靠谱的建站公司加盟品牌?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  如何解决ASP生成WAP建站中文乱码问题?  ,柠檬视频怎样兑换vip?  如何通过商城自助建站源码实现零基础高效建站?  如何解决VPS建站LNMP环境配置常见问题?  如何快速搭建FTP站点实现文件共享?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?  如何在阿里云ECS服务器部署织梦CMS网站?  专业公司网站制作公司,用什么语言做企业网站比较好?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  如何打造高效商业网站?建站目的决定转化率  建站之星多图banner生成与模板自定义指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。