父子窗体间传递JSON格式的数据的代码


Posted in Javascript onDecember 25, 2010

如果某个一级评分项包含评分子项,则点击该评分项时,再弹出一个新窗口,新窗体中列出了当前评分项的所有评分子项列表,供用户进行操作。用户操作完成后,点击“确定”按钮,则返回到父窗体,在子窗体中所有的操作结果,同时要带到父窗体中。同时,如果用户再次点击该评分项,则在弹出子窗体的同时,要将上次操作的结果绑定到对应的操作项上。

上面描述的例子,就涉及到了一个父子窗体间的数据传递。如何实现这一数据传递,当然有很多方法。这里只是记录一下在这个例子中我使用的方法。我的方法是在子窗体点击“确定”按钮时,将操作结果构造成json格式的字符串,通过调用父窗体上的方法:opener.方法(),将json格式数据传递到父窗体上。

此例中构造的json数据类似如下格式:

{"MyData":[

{"bh":"111","lx":"1","df":"10","bz":"aaa"},

{"bh":"112","lx":"2","df":"20","bz":"bbb"},

{"bh":"113","lx":"2","df":"30","bz":"ccc"}

]}

此处子项打分需要保持的分别是bh:编号;lx:类型;df:得分;bz:备注。

按照自己的需要,可以再自己增加需要保持的项。构造此json数据可以放在前台,也可以放在后台。

在此例中,我是放置后台的。代码如下:

StringBuilder jsonBuilder = new StringBuilder(); 
jsonBuilder.Append("@{\""); 
jsonBuilder.Append("MyData"); 
jsonBuilder.Append("\":["); int k = bh.Split(',').Length + 1; 
for (int i = 0; i < bh.Split(',').Length; i++) 
{ 
tem += "update KH_PFX set DF = '"+EncriptLib.EncriptLib.EncodeCode(Convert.ToDouble(df.Split(',')[i].ToString().Trim()))+"',"; 
tem += "BZ = '"+bz.Split(',')[i].ToString().Trim()+"',PFRXM = '"+Session["XM"].ToString()+"',"; 
tem += "PFRBH = '"+Session["YHBH"].ToString()+"',PFRQ = to_date('"+DateTime.Now.ToShortDateString()+"','yyyy-MM-dd')"; 
tem += " where BH = '"+bh.Split(',')[i].ToString().Trim()+"'"; 
tem += "?e"; //此处用此特殊的符号来分隔sql语句 
jsonBuilder.Append("{\"bh\":" + "\"" + bh.Split(',')[i].ToString().Trim() + "\"" + ","); 
jsonBuilder.Append("\"lx\":" + "\"" + lx.Split(',')[i].ToString().Trim() + "\"" + ","); 
jsonBuilder.Append("\"df\":" + "\"" + df.Split(',')[i].ToString().Trim() + "\"" + ","); 
jsonBuilder.Append("\"bz\":" + "\"" + bz.Split(',')[i].ToString().Trim() + "\"" + "},"); 
} 
if(tem != "") 
{ 
jsonBuilder.Remove(jsonBuilder.Length - 1, 1); 
jsonBuilder.Append("]"); 
jsonBuilder.Append("}"); 
Page.ClientScript.RegisterClientScriptBlock(GetType(), "cg", "<Script>window.close();opener.GetZXDF('zxdf" + Request.QueryString["bh"].ToString() + "','" + parent_df.Text.Trim() + "','" + jsonBuilder.ToString() + "',\"" + tem + "\");</Script>"); 
}

"@"符号可以防止在jsonBuilder.ToString()后,转义字符“\”的消失。

调用父窗体的GetZXDF()方法,将json数据传递给父窗体。

下面给出子窗体加载时,绑定json数据的代码

$(function() { //加载时获取json,然后绑定打分结果 
var obj = opener.GetJson($("#txt_YCBH").val()); 
if($.trim(obj) != ""){ 
obj = "(" + obj + ")"; 
obj = eval(obj); 
var data = obj.MyData; 
$.each(data, function(i, n) { 
if(n.lx == "1"){ 
//直接打分类的绑定 
$("#lx" + n.bh).siblings("input").eq(0).val(n.df); 
$("#lx" + n.bh).siblings("input").eq(1).val(n.df); 
$("#lx" + n.bh).parent().parent().next().children().children("textarea").val(n.bz); 
} 
if(n.lx == "2"){ 
//选项打分类的绑定 
$("#lx" + n.bh).siblings("input:text").eq(1).val(n.df); 
$("#lx" + n.bh).siblings("input:checkbox").each(function(){ 
if($.trim($(this).val()) == $.trim(n.df)){ 
$(this).attr("checked",true); 
} 
}); 
$("#lx" + n.bh).parent().parent().parent().next().children().children("textarea").val(n.bz); 
} 
});

opener.GetJson()方法是父窗体上用来向子窗体传递json数据的方法,代码如下:
//通过编号获取对应评分项的子项打分结果的json字符串 
function GetJson(p_bh) 
{ 

 //$("#zxdf" + p_bh).siblings("input").eq(1).val()中保存的就是子窗体传递给父窗体的json数据 
return $("#zxdf" + p_bh).siblings("input").eq(1).val(); 
}
Javascript 相关文章推荐
可以将word转成html的js代码
Apr 11 Javascript
JavaScript省市联动实现代码
Feb 15 Javascript
当滚动条滚动到页面底部自动加载增加内容的js代码
May 13 Javascript
javascript自定义in_array()函数实现方法
Aug 03 Javascript
灵活的理解JavaScript中的this指向
Feb 25 Javascript
Jquery判断form表单数据是否变化
Mar 30 Javascript
浅谈JavaScript 函数参数传递到底是值传递还是引用传递
Aug 23 Javascript
详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例
Feb 17 Javascript
JavaScript基于扩展String实现替换字符串中index处字符的方法
Jun 13 Javascript
vue底部加载更多的实例代码
Jun 29 Javascript
vue项目每30秒刷新1次接口的实现方法
Dec 04 Javascript
js中数组常用方法总结(推荐)
Apr 09 Javascript
javascript自执行函数之伪命名空间封装法
Dec 25 #Javascript
Ext对基本类型的扩展 ext,extjs,format
Dec 25 #Javascript
JQuery live函数
Dec 24 #Javascript
jquery 单击li防止重复加载的实现代码
Dec 24 #Javascript
基于jquery的关于动态创建DOM元素的问题
Dec 24 #Javascript
在JavaScript中获取请求的URL参数
Dec 22 #Javascript
基于Jquery的表格隔行换色,移动换色,点击换色插件
Dec 22 #Javascript
You might like
30 个很棒的PHP开源CMS内容管理系统小结
2011/10/14 PHP
php中设置index.php文件为只读的方法
2013/02/06 PHP
php实现博客,论坛图片防盗链的方法
2016/10/15 PHP
gearman中任务的优先级和返回状态实例分析
2020/02/27 PHP
jquery之empty()与remove()区别说明
2010/09/10 Javascript
两个Javascript小tip资料
2010/11/23 Javascript
javascript 3d 逐侦产品展示(核心精简)
2014/03/26 Javascript
自写的jQuery异步加载数据添加事件
2014/05/15 Javascript
JQuery打造省市下拉框联动效果
2014/05/18 Javascript
用队列模拟jquery的动画算法实例
2015/01/20 Javascript
用JavaScript实现对话框的教程
2015/06/04 Javascript
javascript实现禁止鼠标滚轮事件
2015/07/24 Javascript
javascript中apply、call和bind的使用区别
2016/04/05 Javascript
阻止表单提交按钮多次提交的完美解决方法
2016/05/16 Javascript
12个非常实用的JavaScript小技巧【推荐】
2016/05/18 Javascript
从零开始做一个pagination分页组件
2017/03/15 Javascript
Vue-cli 使用json server在本地模拟请求数据的示例代码
2017/11/02 Javascript
使用vue-router设置每个页面的title方法
2018/02/11 Javascript
tween.js缓动补间动画算法示例
2018/02/13 Javascript
vue请求本地自己编写的json文件的方法
2019/04/25 Javascript
vue引用外部JS的两种种方法
2020/01/28 Javascript
python获取本机外网ip的方法
2015/04/15 Python
Python处理PDF及生成多层PDF实例代码
2017/04/24 Python
python使用udp实现聊天器功能
2018/12/10 Python
python调用虹软2.0第三版的具体使用
2019/02/22 Python
python3爬虫GIL修改多线程实例讲解
2020/11/24 Python
李维斯法国官网:Levi’s法国
2019/07/13 全球购物
政法学院毕业生求职信
2014/02/28 职场文书
购房协议书
2014/04/11 职场文书
高中生逃课检讨书
2014/10/10 职场文书
大学生预备党员自我评价
2015/03/04 职场文书
2015秋季新学期开学寄语
2015/05/28 职场文书
z-index不起作用
2021/03/31 HTML / CSS
python opencv旋转图片的使用方法
2021/06/04 Python
利用JavaScript写一个简单计算器
2021/11/27 Javascript
鲲鹏 CentOS 7 安装Python3.7
2022/05/11 Servers