子窗口给父窗口赋值
今天Insus.NET练习JavaScript,实现从父窗口打开一个子窗口,在子窗口处理一些结果之后,把结果赋值于父窗口的文本框内。可看效果:
在站点创建两个aspx页面,一个是PageA.aspx另一个是PageB.aspx:
在PageA.aspx的<head>节点内,写Javascript脚本,脚本有两个方法,一个是打开子窗口,一个是为文本框设值的方法:

<script type="text/javascript"> function popUp(url) { objSubWin = window.open(url, "Popup", "toolbar=no,scrollbars=no,location=no,statusbar=no,menubar=no,resizable=0,width=300,height=80"); objSubWin.focus(); } function SetValue(val) { var amount = document.getElementById('<% = TextBoxAmount.ClientID %>'); amount.value = val; } </script>
然后在<body>节点内,拉一个TextBox和一个Button:

Amount: <asp:TextBox ID="TextBoxAmount" runat="server" Enabled="false"></asp:TextBox> <asp:Button ID="Button1" runat="server" Text="Call child window" OnClientClick="popUp('PageB.aspx')" />
OK,父页完成,接下来写PageB.aspx子页,还是先写Javascript脚本,也有两个函数,一个是验证文本框只能输入数字,另一个是计算方法,在calc()方法内,有呼叫到父窗口的方法。

<script type="text/javascript"> function isNumeric(keyCode) { return ((keyCode >= 48 && keyCode <= 57) || keyCode == 8) } function calc() { if (window.opener != null && !window.opener.closed) { var qty = document.getElementById('<% = TextBoxqty.ClientID %>'); var price = document.getElementById('<% = TextBoxPrice.ClientID %>'); window.opener.SetValue(parseInt(qty.value) * parseInt(price.value)); } } </script>
在PageB.aspx的<body>节点内,拉两个文本框,一个Button铵钮。

数量<asp:TextBox ID="TextBoxqty" runat="server" onkeydown="return isNumeric(event.keyCode);" onpaste="return false;" Width="50"></asp:TextBox> * 单价<asp:TextBox ID="TextBoxPrice" runat="server" onkeydown="return isNumeric(event.keyCode);" onpaste="return false;" Width="50"></asp:TextBox> <asp:Button ID="Button1" runat="server" Text="Calculate" OnClientClick="calc()" />
另外附加,有关文本框验证的博文:http://www.cnblogs.com/insus/archive/2013/01/27/2878524.html
分类:
JavaScript
, ASP.NET
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
2012-01-27 不重复的随机数
2012-01-27 MS SQL随机数
2011-01-27 T-SQL SUM Functions
2011-01-27 T-SQL MIN Functions
2011-01-27 T-SQL MAX Functions
2011-01-27 T-SQL COUNT Functions
2011-01-27 T-SQL AVG Functions