【原创】08. easyui form控件,回调参数存在后缀 audio controls="controls" style="display: none;"></audio>
- jQuery EasyUI 1.4.3
- springmvc 3.2.6
- 谷歌浏览器,内核版本 chrome 56.0.2924.87
- 360急速浏览器,内核版本 chrome 50.0.2661.102
查看版本方式:http://chrome.360.cn/test/core/
- easyui 使用如下:
123456
$(datagrid.dilogFormID).form(
'submit'
, {
url: datagrid.submitUrl,
iframe:
false
,
onSubmit:
function
(param){
},error:
function
(result){
},success:
function
(res){...}
- spingmvc code:
123456@RequestMapping(value=
"/saveOrUpdateParkAdditional.do"
)
@ResponseBody
public String saveOrUpdateParkAdditional(HttpServletRequest request) {
return
"itemTypeError"
;
}
- 先用谷歌浏览器提交from,返回响应:响应结果是正确的
但是,当我调试js查看success回调函数 参数时,发现 正确结构后面被追加了:<audio controls="controls" style="display: none;"></audio> - 查看easyui源码,发现几处关键代码:
- 这个success回调函数:res 的值是在何处?如何得到到?
12345678910
function
cb() {
var
f = $(
"#"
+ _507); // $("#" + _507) 何时创建的,什么内容?
if
(!f.length) {
return
;
}
f.unbind();
var
data =
""
;
try
{
var
body = f.contents().find(
"body"
);
data = body.html();
- 再跟踪这个 body 的来源:
123456789101112(
function
($) {
function
_503(_504, _505) {
var
opts = $.data(_504,
"form"
).options;
$.extend(opts, _505 || {});
var
_506 = $.extend({}, opts.queryParams);
if
(opts.onSubmit.call(_504, _506) ==
false
) {
return
;
}
$(_504).find(
".textbox-text:focus"
).blur();
var
_507 =
"easyui_frame_"
+ (
new
Date().getTime());
var
_508 = $(
"<iframe id="
+ _507 +
" name="
+ _507 +
"></iframe>"
)
.appendTo(
"body"
);
// here
原来easyui 添加了个iframe,并将服务端的返回值 塞进 该iframe#body
- 那么问题关键点,找到了,就是这个$(...).appendTo("body"),分别在 当前最高版本谷歌(chrome 56.0.2924.87) 和 360急速浏览器(chrome 50.0.2661.102)执行:
1$(
"<iframe id='t2eewqeqwst' name='tews2st'></iframe>"
).appendTo(
'body'
)
验证发现:
- 谷歌,body 存在 auto 元素
补加测试:chrome 55 版本也存在 auto 元素 - 360急速浏览器,body 元素内是干净的。
- 原因找到了,但是至于怎么正面解决还不清楚。
不过我们可以返回非String来避免,比如:Map<String,String> 类型即可避免。
- springmvc controller:
123
@RequestMapping(value=
"/saveOrUpdateParkAdditional.do"
)
@ResponseBody
public List<Map<String,Object>> saveOrUpdateParkAdditional(HttpServletRequest request) { ....}
- 当返回类型 String 时,或者是 List,Map等,内容含有中文是不会导致中文乱码的
- 当返回类型!String 时,且情形如下,会出现中文乱码:
123456@RequestMapping(value=
"/saveOrUpdateParkAdditional.do"
)
@ResponseBody
public String saveOrUpdatePark...{
renturn
"中文"
}
- sss
【原创】08. easyui form控件,回调参数存在后缀 audio controls="controls" style="display: none;"></audio>的更多相关文章
- 前端模板之EasyUI常用控件及参数
CSS类定义 div easyui-window window窗口样式 属性如下: 1) modal:是否生成模态窗口.true[是] false[否] 2) shadow:是否显示窗口阴影.true ...
- [转]easyui常用控件及样式API中文收藏
[转]easyui常用控件及样式收藏 2013-05-06 23:01 30612人阅读 评论(0) 收藏 举报 分类: java ee(5) 目录(?)[+] CSS类定义: div easyu ...
- EasyUI常用控件禁用方法
EasyUI常用控件禁用方法: 1.validatebox可以用的用法:前两种适用于单个的validatebox; 第三种应用于整个form里面的输入框; <1>.$("#id& ...
- C# 跨线程调用form控件技巧及byte[]与string型相互转换
跨线程调用form控件技巧 private delegate void MethodSocket(object obj);//使用托管 ss = "OK"; this.BeginI ...
- 疑似easyui本身bug:easyui时间控件问题,试了几个版本都不行
最近发现easyui时间控件的值格式不支持带斜杠的日期(2016/10/31),必须是2016-10-31这类的才能正常使用,否则默认初始化为当前时间 <input id="Retur ...
- 《zw版·Halcon-delphi系列原创教程》halconxlib控件列表
<zw版·Halcon-delphi系列原创教程>halconxlib控件列表 Halcon v11.01版,com控件,安装后,共有75个控件, 不过最重要的控件,只有两个,T ...
- 在WPF中添加Windows Form控件(包括 ocx控件)
首先,需要向项目中的reference添加两个dll,一个是.NET库中的System.Windows.Forms,另外一个是WindowsFormsIntegration,它的位置一般是在C:\ ...
- Jquery获取EasyUI时间控件的值
jquery easyui日期控件中,在页面里用JS拿到设置的日期值的方法 jquery easyui 日期框 有这样的一个日期文本框: <input type=" value=&qu ...
- easyui时间控件用js实时获取选定的时间的取法
easyui时间控件用js实时获取选定的时间的取法var datetime=$("#id").datetimebox("getValue");不能用 $(& ...
随机推荐
- node项目的基本构建流程或者打开一个node项目的流程
1. 确立项目所需要的所有依赖.框架(比如bootstrap,vue,angular等) 2. 在项目的根目录下创建一个package.json文件,package.json文件是项目的最重要文件之 ...
- 解决Socket粘包问题——C#代码
解决Socket粘包问题——C#代码 前天晚上,曾经的一个同事问我socket发送消息如果太频繁接收方就会有消息重叠,因为当时在外面,没有多加思考 第一反应还以为是多线程导致的数据不同步导致的,让他加 ...
- [leetcode-507-Perfect Number]
We define the Perfect Number is a positive integer that is equal to the sum of all its positive divi ...
- CNN中的卷积核及TensorFlow中卷积的各种实现
声明: 1. 我和每一个应该看这篇博文的人一样,都是初学者,都是小菜鸟,我发布博文只是希望加深学习印象并与大家讨论. 2. 我不确定的地方用了"应该"二字 首先,通俗说一下,CNN ...
- Hugo快速搭建Blog
以往我们搭建blog要么学习一个编程语言+Web开发框架,要么使用现成的blog系统(如WordPress).其实我们还可以使用Hugo.Hugo是由Go语言实现的静态网站生成器,它不需要数据库,所以 ...
- AngularJs + angular-ui-router + bootstrap 实现blog基础导航功能
AngularJs + angular-ui-router + bootstrap 实现blog基础导航功能 核心代码如下 1.index.html <!DOCTYPE html> < ...
- Tomcat学习笔记(一)一个简单的Web服务器
内容为<深入剖析Tomcat>第一章重点,以及自己的总结,如有描述不清的,可查看原书. 一.HTTP协议: 1.定义:用于服务器与客户端的通讯的协议,允许web服务器和浏览器通过互联网进行 ...
- golang路上的小学生系列--使用reflect查找package路径
本文同时发布在个人博客chinazt.cc 和 gitbook 今日看到了一个有趣的golang项目--kolpa(https://github.com/malisit/kolpa). 这个项目可以用 ...
- peoplesoft function PSTREENODE 通过 deptid 获得部门树 全路径 名称
create or replace function getUnitFullName(deptid in varchar) return varchar2 is r ); c int; n ); m ...
- 【hibernate 初探】之 关系映射,ORM
从整理上讲,一个ORM框架(以hibernate为例)所涉及内容无非就是,如何映射,如何检索,还有事务处理.所以从这三方面入手,基本上可以保证将hibernate可以用到自己的项目之中.所以我先说一下 ...