jQuery使用模式窗口实现在主页面和子页面中互相传值的方法。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <script src="/demo/js/jq.js" type="text/javascript"></script> <script type="text/javascript"> function openWindow() { var oldValue = { Name:$("#Name").val(),Age:$("#Age").val() }; var result = popModal("window.html", 300, 200, oldValue); if (result!=null && typeof (result) != "undefined") { $("#Name").val(result.Name); $("#Age").val(result.Age); } } //===================================================================== //功能说明: 弹出一个模式窗口 (测试:IE 和 Firefox 正常, Chrome可以弹出, 但长宽有变而且不是模式, 它本身不支持) //输入参数: 路径,宽度,高度,参数(可选) function popModal(url, width, height, parameter ) { var feature = 'dialogWidth=' + width+'px' + ';dialogHeight=' + height + 'px' + ';dialogTop=' + (screen.height - height) / 2 + 'px' + ';dialogLeft=' + (screen.width - width) / 2 + 'px' + ';help:no;resizable:no;status=no;scroll:no'; if(typeof(parameter)=="undefined") return window.showModalDialog(url, feature); else return window.showModalDialog(url, parameter, feature); } //===================================================================== //功能说明: 弹出一个窗口 //输入参数: 路径,窗口名称,宽度,高度 function pop(helpurl, windowName, width, height) { var feature ='width=' + width + ',height=' + height + ',top=' + (screen.height - height) / 2 + ',left=' + (screen.width - width) / 2 +',toolbar=no,menubar=no,scrollbars=yes,resizable=no,location=no,status=no'; window.open(helpurl, windowName, feature); } </script> </head> <body> <div> 名字<input id="Name" type="text" /><br /> 年龄<input id="Age" type="text" /><br /> <input id="Button1" type="button" value="打开模式窗口" onclick="openWindow()" /> </div> </body> </html>
子页面:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <script src="/demo/js/jq.js" type="text/javascript"></script> <script type="text/javascript"> $(function () { var param = window.dialogArguments; $("#Name").val(param.Name); $("#Age").val(param.Age); }); function closeWindow() { var result = {}; result.Name = $("#Name").val(); result.Age = $("#Age").val(); window.returnValue = result; window.close(); } </script> </head> <body> <div> 名字<input id="Name" type="text" /><br /> 年龄<input id="Age" type="text" /><br /> <input id="Button1" type="button" value="关闭模式窗口" onclick="closeWindow()" /> </div> </body> </html>
网友评论文明上网理性发言 已有0人参与
发表评论: