为了账号安全,请及时绑定邮箱和手机立即绑定

子窗口给父窗口赋值

标签:
JavaScript

今天Insus.NET练习JavaScript,实现从父窗口打开一个子窗口,在子窗口处理一些结果之后,把结果赋值于父窗口的文本框内。可看效果:

 

在站点创建两个aspx页面,一个是PageA.aspx另一个是PageB.aspx:

在PageA.aspx的<head>节点内,写Javascript脚本,脚本有两个方法,一个是打开子窗口,一个是为文本框设值的方法:

View Code

<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:

View Code

 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()方法内,有呼叫到父窗口的方法。

View Code

<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铵钮。

View Code

  数量<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()" />


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消