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 ...
随机推荐
- Jmeter实时性能测试数据的监控
Jmetet实时性能测试数据的监控和展示Jmeter Grafana InfluxDB 安装Grafana配置jmeter安装InfluxDB配置Grafana展示数据一安装InfluxDB 为了方便 ...
- Sort Transformed Array -- LeetCode
Given a sorted array of integers nums and integer values a, b and c. Apply a function of the form f( ...
- Radius报文解析
RADIUS ,是远程认证拨号用户服务的简称.RADIUS原先设计的目的是为拨号用户进行认证和计费.后来经过多次改进,形成了一项通用的认证计费协议,主要完成在网络接入设备和认证服务器之间承载认证.授权 ...
- 10.getter & setter
自定义 Person 类 class Person: NSObject { var name: String? var age: Int? } getter & setter var _nam ...
- telnet 查看端口是否可访问
1. 首先为什么要写这篇文章 说到为什么还得从DNS服务器说起.我在我的电脑上安装了DNS服务器,但是用网络去访问还怎么都访问都不上去.于是我就打开dos窗口,用ping命令查看是否可以ping( ...
- etcd:从应用场景到实现原理的全方位解读
随着CoreOS和Kubernetes等项目在开源社区日益火热,它们项目中都用到的etcd组件作为一个高可用强一致性的服务发现存储仓库,渐 渐为开发人员所关注.在云计算时代,如何让服务快速透明地接入到 ...
- C# 下利用ICSharpCode.SharpZipLib.dll实现文件/目录压缩、解压缩
ICSharpCode.SharpZipLib.dll下载地址 1.压缩某个指定文件夹下日志,将日志压缩到CompressionDirectory文件夹中,并清除原来未压缩日志. #region 压缩 ...
- 解决no declaration can be found for element 'context:component-scan'
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...
- java int转String全部方式的效率对照与深入解析
在java中,大家肯定都会遇到int类型转String类型的情形,知其然知其所以然.总结加分析一下,int类型转String类型有下面几种方式: a+"" String.value ...
- [Algorithm] Maximum Contiguous Subarray algorithm implementation using TypeScript / JavaScript
Naive solution for this problem would be caluclate all the possible combinations: const numbers = [1 ...