Android WebView交互传递json字符串并解析的方法

 更新时间:2018年05月04日 09:45:27   作者:Android-刘旭  
这篇文章主要给大家介绍了关于Android中WebView交互传递json字符串并解析的相关资料,文中通过示例代码介绍的非常详细,对各位Android开发者具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

前言

我们大家都知道WebView交互中可以传递基本数据类型的数据值,比如常用的int,String.

但是WebView也可以传递一种很重要很常用的数据格式-json数据.

传递json和传递String数据是一样的,关键就是HTML5端对json数据通过eval()函数进行解析

传递过程中android端调用的最重要的一个函数就是:

addJavascriptInterface(new MyObject(this,”dd”),”my”); 这个函数有两个参数,第一个参数传入的是含有实现了JavaScript中的方法,并且使用@JavascriptInterface注解标识这个方法是被JS代码调用的,第二个参数是一个桥接字符串,这个桥接字符串可以随意定义,只要android端和JavaScript端保持一致就可以.

下面附上传递json数据的完整Demo

index.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>测试Android Json传值</title>
 <script src="http://cdn.hcharts.cn/jquery/jquery-1.8.3.min.js"></script>
 <script src="http://cdn.hcharts.cn/highcharts/highcharts.js"></script>

 <script type="text/javascript">
$(function(){
 //通过暴露的my对象来获取数据
 var data = my.getData();
 //将json字符串转换为数组
 var f = eval(data);
 //向表格填充数据
 for(var i = 0;i<f.length;i++){
 var en = f[i];
 $("table").append("<tr><td>"+en.age+"</td><td>"+en.name+"</td><td>"+en.uint+"</td></tr>");
 }
 });
 </script>
</head>
<body>
人员表
<div>
 <table id="table" border="1" bgcolor="#ffddff"></table>
</div>
</body>
</html>

MainActivity.java

package com.geocompass.testdeliverjson;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;
public class MainActivity extends AppCompatActivity {
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 WebView wv = (WebView) findViewById(R.id.wv);
 WebSettings settings = wv.getSettings();
 //调用WebView关联的WebSettings中setJavaScriptEnable(true)方法。
 settings.setJavaScriptEnabled(true);
 wv.loadUrl("file:///android_asset/index.html");
 //调用WebView关联的WebSettings中addJavaScriptInterface
 wv.addJavascriptInterface(new MyObject(this,"dd"),"my");
 }
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/activity_main"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
tools:context="com.geocompass.testdeliverjson.MainActivity">
 <WebView
 android:id="@+id/wv"
 android:layout_width="match_parent"
android:layout_height="match_parent"></WebView>
</RelativeLayout>

MyObject.java

package com.geocompass.testdeliverjson;
import android.content.Context;
import android.util.Log;
import android.webkit.JavascriptInterface;
import com.google.gson.Gson;
import java.util.ArrayList;
import java.util.List;

/**
 * Created by liuxu on 2017/2/13.
 */

public class MyObject {
 public static final String TAG = MyObject.class.getSimpleName() ;
 private Context mContext;
 private String data;
 public MyObject(Context c,String data){
 this.data = data;
 mContext = c;
 }

 /**
 * 获取person字符串传Html
 * @return
 */
 @JavascriptInterface
 public String getData(){

 List<Person> mlist = new ArrayList<>();
 for (int i = 0; i <10 ; i++) {
  mlist.add(new Person("姓名"+i,i+"","工作单位"+i));
 }
 Gson gson = new Gson();
 String d = gson.toJson(mlist);
 Log.d(TAG, "getData: dddd"+d);
 return d;
 }
}

Person.java

package com.geocompass.testdeliverjson;
/**
 * Created by liuxu on 2017/2/13.
 */
public class Person {
 public String name;
 public String age;
 public String uint;
 public Person(String name, String age, String uint) {
 this.name = name;
 this.age = age;
 this.uint = uint;
 }
}

运行效果截图如下

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • android如何取得本地通讯录的头像的原图的实现代码

    android如何取得本地通讯录的头像的原图的实现代码

    这篇文章主要介绍了android如何取得本地通讯录的头像的原图的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-12-12
  • android 9PNG图片制作过程(图文介绍)

    android 9PNG图片制作过程(图文介绍)

    我们想要是有些图片可以拉伸而不失真多好啊,这时候我们就要想起android为我们提供的9.png格式的图片了,9.png格式的图片是安卓平台上新创的一种被拉伸却不失真的玩意
    2013-01-01
  • Android实现闪屏效果

    Android实现闪屏效果

    这篇文章主要为大家详细介绍了Android实现闪屏效果,实现“一闪而过”效果进入页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android沉浸式顶部实现代码及效果

    Android沉浸式顶部实现代码及效果

    这篇文章主要介绍了Android沉浸式顶部实现代码及效果,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Android编程获取全局Context的方法

    Android编程获取全局Context的方法

    这篇文章主要介绍了Android编程获取全局Context的方法,实例分析了基于Application类获取全局Context的实现步骤与相关技巧,需要的朋友可以参考下
    2016-01-01
  • Android实现网易云推荐歌单界面

    Android实现网易云推荐歌单界面

    大家好,本篇文章主要讲的是Android实现网易云推荐歌单界面,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-02-02
  • Flutter状态管理Provider的使用示例详解

    Flutter状态管理Provider的使用示例详解

    这篇文章主要为大家介绍了Flutter状态管理Provider的使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Android中使用AsyncTask做下载进度条实例代码

    Android中使用AsyncTask做下载进度条实例代码

    这篇文章主要介绍了Android中使用AsyncTask做下载进度条实例代码的相关资料,这里附有实例代码,具有一定参考价值,需要的朋友可以参考下
    2017-01-01
  • 新版Android studio导入微信支付和支付宝官方Demo问题解决大全

    新版Android studio导入微信支付和支付宝官方Demo问题解决大全

    这篇文章主要为大家详细介绍了新版Android studio导入微信支付和支付宝官方Demo问题的解决大全,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • Flutter中数据存储的四种方式小结

    Flutter中数据存储的四种方式小结

    在 Flutter 中,存储是指用于本地和远程存储和管理数据的机制,本给大家介绍了Flutter中不同存储选项的概述和示例,通过代码示例讲解的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2023-11-11

最新评论