主页 > 知识库 > 子窗口给父窗口赋值实现思路及案例演示

子窗口给父窗口赋值实现思路及案例演示

热门标签:Mysql连接数设置 银行业务 电子围栏 团购网站 Linux服务器 服务器配置 阿里云 科大讯飞语音识别系统
今天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()" />

另外附加,有关文本框验证的文章:https://www.jb51.net/article/33586.htm
您可能感兴趣的文章:
  • JavaScript子窗口ModalDialog中操作父窗口对像
  • iframe 父窗口和子窗口相互的调用方法集锦
  • 子窗口、父窗口和Silverlight之间的相互调用
  • js 父窗口控制子窗口的行为-打开,关闭,重定位,回复
  • 用javascript父窗口控制只弹出一个子窗口
  • 父窗口获取弹出子窗口文本框的值

标签:大理 衢州 广元 衡水 萍乡 枣庄 蚌埠 江苏

巨人网络通讯声明:本文标题《子窗口给父窗口赋值实现思路及案例演示》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266