JFinal中json的使用
之前Java开发一直使用的是经典的ssh,去年接触了jfinal,觉得jfinal的魅力非常之大,让我无法自拔,现在还深深地陷在其中。
简单的介绍一下jfinal,jfinal短小精悍,让java有了PHP一般的开发速度,急速的开发速度之外其他的方面毫不逊色,我谈谈几点自己使用jfinal的感受吧。
- 传统的ssh框架,mybatis和springmvc等,需要配置大量的配置文件,一层层,感觉无比的繁琐。而jfinal甚至可以达到0配置文件,当然他也是支持配置文件的,这种感觉真是太棒了!
- jfinal一个框架搞定了所有的事情,什么AOP啊、事务处理啊等等。不用担心包冲突啊,杂七杂八的,一个jar包解决所有问题。
- jfinal独创的Db+Record模式,model层无需字段直接操作数据库。
- jfinal同样支持各种各样的插件,功能强大。
- 我在使用jfinal的时候最大的感觉是,他打破了传统的编程模式,编码中dao层直接结合了model层,你甚至可以在action层上写sql代码,感觉真是无招胜有招!太随心应手了!
回到正题
我们来说一说jfinal中的json使用。
在struts2中或者是别的框架我相信大家都知道怎么使用json向前台传值。json字符串拼接,或者用第三方jar包解析对象成json字符串。
在jfinal中直接提供了一个方法renderJson();
这个方法有这几种用法
1. 输出一个空的json
2. 把一个对象解析成json输出
3. 输出一个json字符串
4. 把一个字符数组按json格式输出
5. 输出把key和value组合成json输出
其他的我就不介绍了,关键我说一下我在使用json字符串输出的时候遇见的问题
一开始我在后台使用的renderText()输出字符串,并且用的是单引号,我是这么写的
renderText("{'state':'success','msg':'评论成功!'}");
结果我发现这样竟然前台无法解析!原来单引号对于前台是无效的,于是我就换一个写法。
renderText("{state:\"success\",msg:\"评论成功!\"}");
发现还是不行!于是我想起了renderJson这个方法
renderJson("{'state':'success','msg':'评论成功!'}");
renderJson("{state:\"success\",msg:\"评论成功!\"}");
这两种都不可以!!只好再试一下renderText()!
renderText("{\"state\":\"success\",\"msg\":\"评论成功!\"}");
结果成功了!在前台使用JSON.parse()可以解析这个对象。但是郁闷的是,我在前台使用了一个方法isJson(data)。判断出来的竟然是false,这可就头大了。明明可以解析,但判断的确实false,而且用工具检测也是json对象,有点小郁闷。最后我试验了jfinal中的renderJson
renderJson("{\"state\":\"success\",\"msg\":\"评论成功!\"}");
发现isJson(data)结果为true了,太棒了!但是确开始报另外一个错误,JSON.parse()解析错误!我尝试了直接用js打印了data,msg竟然可以直接打印,果断删除了JSON.parse()函数,直接使用data.属性。jfinal直接把他解析了,在前台都不用再处理!在一个觉得jfinal非常棒!
总结一下
1.使用jfinal渲染json字符串必须使用转义符和双引号,而且使用renderJson方法,如下面
renderJson("{\"state\":\"success\",\"msg\":\"评论成功!\"}");
2.使用jfinal的renderJson在前台无需再进行处理,直接可以使用对象.属性
JFinal中json的使用的更多相关文章
- C#中JSON序列化和反序列化
有一段时间没有到博客园写技术博客了,不过每天逛逛博客园中大牛的博客还是有的,学无止境…… 最近在写些调用他人接口的程序,用到了大量的JSON.XML序列化和反序列化,今天就来总结下json的序列化和反 ...
- android中Json的一些应用
JSON(JavaScript Object Notation) :一种轻量级的数据交换格式,基于JavaScript的一个子集. JSON采用完全独立于语言的文本格式,使JSON成为理想的数据交换语 ...
- 解决MVC中JSON字符长度超出限制的异常
解决MVC中JSON字符长度超出限制的异常 解决方法如下: <configuration> <system.web.extensions> <scripting> ...
- Asp.net中Json的序列化和反序列化(一)
JSON是专门为浏览器中的网页上运行的JavaScript代码而设计的一种数据格式.在网站应用中使用JSON的场景越来越多,本文介绍ASP.NET中JSON的序列化和反序列化,主要对JSON的简单介绍 ...
- .NET3.5中JSON用法以及封装JsonUtils工具类
.NET3.5中JSON用法以及封装JsonUtils工具类 我们讲到JSON的简单使用,现在我们来研究如何进行封装微软提供的JSON基类,达到更加方便.简单.强大且重用性高的效果. 首先创建一个类 ...
- Net中JSON序列化和反序列化处理(日期时间特殊处理)
0 缘由 笔者最近在web api端使用Json.Net进行序列化处理,而在调用端使用DataContractSerializer进行反序列化,遇到日期时间处理反序列化不成功[备注:笔者使用Net ...
- ASP.NET中JSON的序列化和反序列化
JSON是专门为浏览器中的网页上运行的JavaScript代码而设计的一种数据格式.在网站应用中使用JSON的场景越来越多,本文介绍 ASP.NET中JSON的序列化和反序列化,主要对JSON的简单介 ...
- ASP.NET 中JSON 的序列化和反序列化
JSON是专门为浏览器中的网页上运行的JavaScript代码而设计的一种数据格式.在网站应用中使用JSON的场景越来越多,本文介绍ASP.NET中JSON的序列化和反序列化,主要对JSON的简单介绍 ...
- 关于http接口开发中json格式数据编码问题处理
关于http接口开发中json格式数据编码问题处理 在实际工作中,接口很多时候返回json格式,但有时返回的格式会有编码问题 假设如下接口:http://service.test.com/interf ...
随机推荐
- 洛谷—— P3908 异或之和
https://www.luogu.org/problemnew/show/P3908 题目描述 求1 \bigoplus 2 \bigoplus\cdots\bigoplus N1⨁2⨁⋯⨁N 的值 ...
- 洛谷——P1755 斐波那契的拆分
P1755 斐波那契的拆分 题目背景 无 题目描述 已知任意一个正整数都可以拆分为若干个斐波纳契数,现在,让你求出n的拆分方法 输入输出格式 输入格式: 一个数t,表示有t组数据 接下来t行,每行一个 ...
- phpredis Floating point exception
发生在高版本的gcc编译后的so用于低版本gcc编译出来的php, 解决方法, 加上参数-Wl,--hash-style=sysv phpize ./configure vi Makefile CC ...
- 发布Android开源库,看这个文章就够了!
最近在Flipboard实习期间写了一个轮播工具,技术上没什么难点,不过动画效果还是不错的,决定改改代码写个库开源出去.项目地址:http://github.com/chengdazhi/Decent ...
- QT5.8+vs2015配置以及qt creater中出现中文乱码解决办法之一
1.参考此文档:QT5.6+vs2015配置: 2.出现乱码问题时候 在头文件上加入: #pragma execution_character_set("utf-8") //加入这 ...
- 基于pydash临控linux服务器
pydash项目地址:https://github.com/k3oni/pydash 一.安装过程 1.安装pip dnf install git python-pip -ypip install v ...
- 新人补钙系列教程之:AS 与 JS 相互通信
比较常用的,AS 调用 JS private function callJS():void{ ExternalInterface.addCallback("callbackQQPay&quo ...
- 2017.8.5 VMware的介绍与安装
1 VMware简介 官网地址:http://www.vmware.com VMware的功能: 是一个虚拟PC的软件,可以在现有的操作系统上虚拟出一个新的硬件环境,相当于模拟出一台新的PC,以此来实 ...
- 倍福TwinCAT(贝福Beckhoff)基础教程2.2 TwinCAT常见类型使用和转换_枚举
在Duts的文件夹上右击,可以声明一个枚举类型,按照格式填写所有类型(注意枚举的元素前面都是逗号,最后一个不需要符号) 在正常使用的时候,枚举的单词可以当全局变量来用 更多教学视频和资料下 ...
- hbuilder - wap to app
官方文档: http://www.dcloud.io/wap2app.html 新建Wap2App,示例网址:www.baidu.com 随后,我们可以在 最后,我们可以 打包完成以后,下载即可