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 相关文章推荐
限制复选框的最大可选数
Jul 01 Javascript
JavaScript实现获取dom中class的方法
Feb 09 Javascript
js与jquery分别实现tab标签页功能的方法
Nov 18 Javascript
JS实用的带停顿的逐行文本循环滚动效果实例
Nov 23 Javascript
详解Node.js中exports和module.exports的区别
Apr 19 Javascript
vue实现element-ui对话框可拖拽功能
Aug 17 Javascript
Vue组件的使用及个人理解与介绍
Feb 09 Javascript
基于JS实现web端录音与播放功能
Apr 17 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
Apr 28 Javascript
vue使用video.js进行视频播放功能
Jul 18 Javascript
小程序新版订阅消息模板消息
Dec 31 Javascript
ES6学习笔记之let与const用法实例分析
Jan 22 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
ThinkPHP3.1新特性之多数据库操作更加完善
2014/06/19 PHP
10个实用的PHP正则表达式汇总
2014/10/23 PHP
PHP实现的操作数组类库定义与用法示例
2019/05/24 PHP
JQuyer $.post 与 $.ajax 访问WCF ajax service 时的问题需要注意的地方
2011/09/20 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
2013/09/30 Javascript
js 距离某一时间点时间是多少实现代码
2013/10/14 Javascript
javascript使用数组的push方法完成快速排序
2014/09/15 Javascript
jQuery使用animate创建动画用法实例
2015/08/07 Javascript
基于javascript实现tab切换特效
2016/03/29 Javascript
webpack打包js的方法
2018/03/12 Javascript
Vue组件中prop属性使用说明实例代码详解
2018/05/31 Javascript
Angular 2使用路由自定义弹出组件toast操作示例
2019/05/10 Javascript
编写更好的JavaScript条件式和匹配条件的技巧(小结)
2019/06/27 Javascript
js前端对于大量数据的展示方式及处理方法
2020/12/02 Javascript
[49:13]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第一局
2016/02/27 DOTA
[01:48]帕吉至宝加入游戏,遗迹战场现“千劫神屠”
2018/04/07 DOTA
python中根据字符串调用函数的实现方法
2016/06/12 Python
Python中functools模块的常用函数解析
2016/06/30 Python
Python学习笔记之图片人脸检测识别实例教程
2019/03/06 Python
Python Django实现layui风格+django分页功能的例子
2019/08/29 Python
Python迭代器iterator生成器generator使用解析
2019/10/24 Python
基于Pyinstaller打包Python程序并压缩文件大小
2020/05/28 Python
python 6行代码制作月历生成器
2020/09/18 Python
Python判断变量是否是None写法代码实例
2020/10/09 Python
全面解析CSS Media媒体查询使用操作(推荐)
2017/08/15 HTML / CSS
利用HTML5 Canvas API绘制矩形的超级攻略
2016/03/21 HTML / CSS
俄罗斯连接商品和买家的在线平台:goods.ru
2020/11/30 全球购物
大学生2014全国两会学习心得体会
2014/03/10 职场文书
寄语是什么意思
2014/04/10 职场文书
企业宣传标语
2014/06/09 职场文书
应届本科毕业生求职信
2014/07/23 职场文书
教师学习群众路线心得体会
2014/11/04 职场文书
打架检讨书
2015/01/27 职场文书
2015年办税服务厅工作总结
2015/07/23 职场文书
《黄山奇石》教学反思
2016/02/18 职场文书
MySQL中正则表达式(REGEXP)使用详解
2022/07/07 MySQL