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

所属分类: 软件编程 / Android 阅读数: 37
收藏 0 赞 0 分享

前言

我们大家都知道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中加入名片扫描功能实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿微信发表说说实现拍照、多图上传功能

这篇文章主要为大家详细介绍了Android仿微信发表说说实现拍照、多图上传功能,使用Retrofit2.0技术,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

设置Android系统永不锁屏永不休眠的方法

在进行Android系统开发的时候,有些特定的情况需要设置系统永不锁屏,永不休眠。本篇文章给大家介绍Android 永不锁屏,开机不锁屏,删除设置中休眠时间选项,需要的朋友一起学习吧
收藏 0 赞 0 分享

Android Retrofit 2.0框架上传图片解决方案

这篇文章主要介绍了Android Retrofit 2.0框架上传一张与多张图片解决方案,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义等待对话框

这篇文章主要为大家详细介绍了Android自定义等待对话框的实现方法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中Window添加View的底层原理

这篇文章主要介绍了Android中Window添加View的底层原理,需要的朋友可以参考下
收藏 0 赞 0 分享

Android调用系统默认浏览器访问的方法

这篇文章主要介绍了Android调用系统默认浏览器访问的方法的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android开发退出程序的方法汇总

Android程序有很多Activity,比如说主窗口A,调用了子窗口B,子窗口B又调用子窗口C,back返回子窗口B后,在B中如何关闭整个Android应用程序呢? 下面脚本之家小编就给大家介绍android开发退出程序的几种方法,感兴趣的朋友参考下吧
收藏 0 赞 0 分享

Android程序开发中单选按钮(RadioGroup)的使用详解

在android程序开发中,无论是单选按钮还是多选按钮都非常的常见,接下来通过本文给大家介绍Android程序开发中单选按钮(RadioGroup)的使用,需要的朋友参考下吧
收藏 0 赞 0 分享

Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中

这篇文章主要介绍了Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多