接着上篇Android中WebView加载本地Html,与JavaScript与Android方法相互传值,今天来一篇续集,为什么要来续集呢,感觉自己还有没有交代完的部分,于是在这里再次交代一下,在Android中我们需要将给复杂的数据传到Html页面,我们该怎么做?

大家作为一直搞android或IOS的小伙伴们,有好多对Html都了解不是太多,于是思考了一番,无非就是向Html页面传值吗?我就只会传字符串等基本的数据类型,遇到像List或Map中多层嵌套的复杂数据我该怎么办?我只会字符串,我只会字符串,我只会字符串,于是我是想到了JSON,JSON作为数据交换的一种方式,我是该选择JSON字符串来帮我完成复杂的数据交换,是因为Android或JavaScript中都JSON转换的方法,能够方便的数据转换。

上面我已经把问题抛了出来问题,解决的方法也已经给出。下面来一个简单的例子来说明一下实现方法。

案例说明,我要将一个List传到页面做一个表格,就这么简单。

1.创建一个Person对象

package com.lidong.androiddemo;/** * Created by lidong on 16/7/2 */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;    }}

2.创建MyObeject

package com.lidong.androiddemo;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 lidong on 16/6/29. */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 mlist = new ArrayList<>();        for (int i = 0; i <10 ; i++) {            mlist.add(new Person("Li"+i,i+"","com"+i));        }        Gson gson = new Gson();        String d  = gson.toJson(mlist);        Log.d(TAG, "getData: dddd"+d);        return d;    }}

3.MainActivity的实现

public class MainActivity extends AppCompatActivity {    private static final String TAG = MainActivity.class.getSimpleName();    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        WebView webView = (WebView) findViewById(R.id.webView);        WebSettings settings = webView.getSettings();        //调用WebView关联的WebSettings中setJavaScriptEnable(true)方法。        settings.setJavaScriptEnabled(true);        webView.loadUrl("file:///android_asset/index.html");        //调用WebView关联的WebSettings中addJavaScriptInterface        webView.addJavascriptInterface(new MyObject(this,"dd"),"my");    }}

4.index.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;ivar en = f[i];     $("table").append(""+en.age+""+en.name+""+en.uint+"");     }   });    script>head><body>人员表<div >    <table id="table" border="1"  bgcolor="#ffddff">table>div>body>html>

这个案例基本上就四个步骤,通过这篇文章的学习妈妈在也不会担心android向html传复杂的数据了,谢谢学习

更多相关文章

  1. android程序实现简单拨号器功能
  2. Android百度地图之位置定位和附近查找代码简单实现 (上)
  3. Android实现网络视频播放
  4. Android(安卓)视频列表(RecyclerView)实现自动播放
  5. Google公布Android数据,年增长250%,每天激活85万台Android设备
  6. Android百度地图之位置定位和附近查找代码简单实现 (上)
  7. Android中WebView加载本地Html,与JavaScript与Android方法相互传
  8. 安卓软硬结合,热点技术实践总结:《Android音频口数据通信开发》 |
  9. 用android:clipChildren来实现红心变大特效 - 喜糖

随机推荐

  1. 【姿势】Android(安卓)和 Mac 爆毁灭级安
  2. Android如何连接MySQL数据库
  3. .NET程序员的iOS面试之旅
  4. Android中的表格布局详解
  5. Android(安卓)自定义Spinner字体、颜色、
  6. Android(安卓)模拟器解决公司网络内无法
  7. Android(安卓)Studio构建工具Gradle构建
  8. [Android]BootChart在Android中的应用
  9. Android(安卓)TV开发总结(六)构建一个TV ap
  10. 6、与iOS、Android的交互 实践篇——传递