js接收并转化Java中的数组对象的方法


Posted in Javascript onAugust 11, 2016

在做项目时,要向ocx控件下发命令,就要在js中得到java中的对象,然后拼成一种格式,下发下去。。。当对象是一个时比较简单,但如果对象是一个数组时,就略显麻烦了。

开始我以为有简单的方式,可以直接进行内容的转化,后来发现不可以,网上说js与java没有桥接的东西,所以呢:

我的解决方案是:在action层,将java的对象数组转化为Json串,而在js中,再把json转化为数组对象。

1.将java的对象数组转化为Json串:

要用到两个类:

net.sf.json.JSONObject
net.sf.json.JSONArray


//将每个vehicle对象拼接为json格式的对象,用于命令下发
JSONObject json = JSONObject.fromObject(v); //v即对象
jsonArray.add(json);
//System.out.println(jsonArray.toString());
//用于命令下发
sendCommandList = jsonArray.toString();

将其放在for循环中。

2.js将其转化为对象数组:

//注意:此时得到的是Json串。

//注意:要加上escapeJavaScript="false" escape="false" ,否则传过来Json字符串中的引号都会被解析成为"

var szJsonStr = '<s:property escapeJavaScript="false" escape="false" value="sendCommandList" />';

最后:

//把Json字符串转化为对象数组
var addVehicleArray = eval(szJsonStr);

在用的时候,就直接用addVehicleArray[i].vehicleType;即可以了。。。。。。

扩展:

JSONObject与JSONArray的使用

1.JAR包简介

要使程序可以运行必须引入JSON-lib包,JSON-lib包同时依赖于以下的JAR包:

commons-lang.jar
commons-beanutils.jar
commons-collections.jar
commons-logging.jar
ezmorph.jar
json-lib-2.2.2-jdk15.jar

2.JSONObject对象使用

JSON-lib包是一个beans,collections,maps,java arrays 和XML和JSON互相转换的包。在本例中,我们将使用JSONObject类创建JSONObject对象,然后我们打印这些对象的值。为了使用JSONObject对象,我们要引入"net.sf.json"包。为了给对象添加元素,我们要使用put()方法。

2.1.实例1

package jsontest;

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;


public class JSONObjectSample {


  // 创建JSONObject对象
  private static JSONObject createJSONObject() {
    JSONObject jsonObject = new JSONObject();
    jsonObject.put("username", "huangwuyi");
    jsonObject.put("sex", "男");
    jsonObject.put("QQ", "413425430");
    jsonObject.put("Min.score", new Integer(99));
    jsonObject.put("nickname", "梦中心境");
    return jsonObject;
  }


  public static void main(String[] args) {
    JSONObject jsonObject = JSONObjectSample.createJSONObject();//静待方法,直接通过类名+方法调用
    // 输出jsonobject对象
    System.out.println("jsonObject:" + jsonObject);


    // 判读输出对象的类型
    boolean isArray = jsonObject.isArray();
    boolean isEmpty = jsonObject.isEmpty();
    boolean isNullObject = jsonObject.isNullObject();
    System.out.println("是否为数组:" + isArray + ", 是否为空:" + isEmpty
        + ", isNullObject:" + isNullObject);


    // 添加属性,在jsonObject后面追加元素。
    jsonObject.element("address", "福建省厦门市");
    System.out.println("添加属性后的对象:" + jsonObject);


    // 返回一个JSONArray对象
    JSONArray jsonArray = new JSONArray();
    jsonArray.add(0, "this is a jsonArray value");
    jsonArray.add(1, "another jsonArray value");
    jsonObject.element("jsonArray", jsonArray);
    //在jsonObject后面住家一个jsonArray
    JSONArray array = jsonObject.getJSONArray("jsonArray");
    System.out.println(jsonObject);
    
    
    System.out.println("返回一个JSONArray对象:" + array);
    // 添加JSONArray后的值
    // {"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
    System.out.println("结果=" + jsonObject);


    // 根据key返回一个字符串
    String username = jsonObject.getString("username");
    System.out.println("username==>" + username);


    // 把字符转换为 JSONObject
    String temp = jsonObject.toString();
    JSONObject object = JSONObject.fromObject(temp);
    // 转换后根据Key返回值
    System.out.println("qq=" + object.get("QQ"));


  }


}

输出结果

jsonObject:{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境"}
是否为数组:false, 是否为空:false, isNullObject:false
添加属性后的对象:{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市"}
{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
返回一个JSONArray对象:["this is a jsonArray value","another jsonArray value"]
结果={"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
username==>huangwuyi
qq=413425430

2.2.实例2.

package jsontest;


import net.sf.json.JSONArray;
import net.sf.json.JSONObject;


public class JSONTest {
  public static void main(String args[])
  {
    JSONObject jsonObj0 = new JSONObject();
    JSONObject jsonObj = new JSONObject();
    JSONObject jsonObj2 = new JSONObject();
    JSONObject jsonObj3 = new JSONObject();
    JSONArray jsonArray = new JSONArray();
    
    //创建jsonObj0
    jsonObj0.put("name0", "zhangsan");
    jsonObj0.put("sex1", "female");
    System.out.println("jsonObj0:"+jsonObj0);
    
    //创建jsonObj1
    jsonObj.put("name", "xuwei");
    jsonObj.put("sex", "male");
    System.out.println("jsonObj:"+jsonObj);
  
    //创建jsonObj2,包含两个条目,条目内容分别为jsonObj0,jsonObj1
    jsonObj2.put("item0", jsonObj0);
    jsonObj2.put("item1", jsonObj);
    System.out.println("jsonObj2:"+jsonObj2);
    
    //创建jsonObj3,只有一个条目,内容为jsonObj2
    jsonObj3.element("j3", jsonObj2);
    System.out.println("jsonObj3:"+jsonObj3);
  
    //往JSONArray中添加JSONObject对象。发现JSONArray跟JSONObject的区别就是JSONArray比JSONObject多中括号[]
    jsonArray.add(jsonObj);
    System.out.println("jsonArray:"+jsonArray);
    
    JSONObject jsonObj4 = new JSONObject();
    jsonObj4.element("weather", jsonArray);
    System.out.println("jsonObj4:"+jsonObj4);
  }
}

输出结果:

jsonObj0:{"name0":"zhangsan","sex1":"female"}

jsonObj:{"name":"xuwei","sex":"male"}

jsonObj2:{"item0":{"name0":"zhangsan","sex1":"female"},"item1":{"name":"xuwei","sex":"male"}}

jsonObj3:{"j3":{"item0":{"name0":"zhangsan","sex1":"female"},"item1":{"name":"xuwei","sex":"male"}}}

jsonArray:[{"name":"xuwei","sex":"male"}]

jsonObj4:{"weather":[{"name":"xuwei","sex":"male"}]}

以上这篇js接收并转化Java中的数组对象的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 表格分页等操作实现代码(pagedown,pageup)
Apr 11 Javascript
JS小功能(列表页面隔行变色)简单实现
Nov 28 Javascript
jQuery实现的多屏图像图层切换效果实例
May 07 Javascript
简介AngularJS的视图功能应用
Jun 17 Javascript
js鼠标单击和双击事件冲突问题的快速解决方法
Jul 11 Javascript
KnockoutJS 3.X API 第四章之数据控制流with绑定
Oct 10 Javascript
js数组与字符串常用方法总结
Jan 13 Javascript
jQuery实现的鼠标滚轮控制图片缩放功能实例
Oct 14 jQuery
在vue.js中使用JSZip实现在前端解压文件的方法
Sep 05 Javascript
vue实现前台列表数据过滤搜索、分页效果
May 28 Javascript
基于Vue3.0开发轻量级手机端弹框组件V3Popup的场景分析
Dec 30 Vue.js
给原生html中添加水印遮罩层的实现示例
Apr 02 Javascript
Js调用Java方法并互相传参的简单实例
Aug 11 #Javascript
JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()
Aug 11 #Javascript
基于js对象,操作属性、方法详解
Aug 11 #Javascript
JS中的hasOwnProperty()和isPrototypeOf()属性实例详解
Aug 11 #Javascript
Node.js中防止错误导致的进程阻塞的方法
Aug 11 #Javascript
浅谈js中对象的使用
Aug 11 #Javascript
js倒计时简单实现代码
Aug 11 #Javascript
You might like
老生常谈PHP面向对象之注册表模式
2017/05/26 PHP
php实现和c#一致的DES加密解密实例
2017/07/24 PHP
prototype Element学习笔记(Element篇三)
2008/10/26 Javascript
javascript IFrame 强制刷新代码
2009/07/23 Javascript
js DOM模型操作
2009/12/28 Javascript
js location.replace与location.reload的区别
2010/09/08 Javascript
js模拟滚动条(横向竖向)
2013/02/22 Javascript
Jquery动态改变图片IMG的src地址示例
2013/06/25 Javascript
IE6-8中Date不支持toISOString的修复方法
2014/05/04 Javascript
jQuery 常见小例汇总
2016/12/14 Javascript
JavaScript实现经典排序算法之选择排序
2016/12/28 Javascript
微信JSAPI Ticket接口签名详解
2020/06/28 Javascript
JavaScript中的null和undefined用法解析
2019/09/30 Javascript
ES6箭头函数和扩展实例分析
2020/05/23 Javascript
VUE使用axios调用后台API接口的方法
2020/08/03 Javascript
[02:36]DOTA2混沌骑士 英雄基础教程
2013/11/26 DOTA
Python中set与frozenset方法和区别详解
2016/05/23 Python
python 自动化将markdown文件转成html文件的方法
2016/09/23 Python
使用Python3 编写简单信用卡管理程序
2016/12/21 Python
python进行两个表格对比的方法
2018/06/27 Python
Python3 log10()函数简单用法
2019/02/19 Python
对django中foreignkey的简单使用详解
2019/07/28 Python
pandas中DataFrame修改index、columns名的方法示例
2019/08/02 Python
Python自定义聚合函数merge与transform区别详解
2020/05/26 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
2020/06/02 Python
Python如何在单元测试中给对象打补丁
2020/08/03 Python
新东网科技Java笔试题
2012/07/13 面试题
财务管理专业应届毕业生求职信
2013/09/22 职场文书
高中同学聚会邀请函
2014/01/11 职场文书
软件专业毕业生个人自我鉴定
2014/04/17 职场文书
学术诚信承诺书
2014/05/26 职场文书
医院义诊活动总结
2014/07/04 职场文书
旅游局领导班子“四风”问题对照检查材料思想汇报
2014/09/29 职场文书
篮球比赛通讯稿
2015/07/18 职场文书
交通安全主题班会
2015/08/12 职场文书
OpenCV3.3+Python3.6实现图片高斯模糊
2021/05/18 Python