弹出页面传值的问题,一点建议

本文详细介绍ASP.NET中页面间的传值方法,包括QueryString、Session、Server.Transfer等,并重点讲解如何利用JavaScript实现在弹出窗口与父窗口间的值传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天碰到一个弹出对话框(PopUp dialog)的问题, 因该是个傻瓜问题, 但是还是让我研究了半天, 总结了一些前人经验, 拿出来跟大家分享一下!
在ASP.Net中页面之间的传值方法有很多,但是打开和关闭新的窗口,靠的还是JavaScript 下的 Windows对象譬如打开窗口open(<URL字符串>, <窗口名称字符串>, <参数字符串>);

<URL字符串>:描述所打开的窗口打开哪一个网页。如果留空(''),则不打开任意网页。
<窗口名称字符串>:描述被打开的窗口的名称(window.name),可以使用'_top'、'_blank'等内建名称。这里的名称跟“<a href="..." target="...">”里的“target”属性是一样的。
<参数字符串>:描述被打开的窗口的样貌。如果只需要打开一个普通窗口,该字符串留空(''),如果要指定样貌,就在字符串里写上一到多个参数,参数之间用逗号隔开。

有些参数还是要知道的

top=#
 窗口顶部离开屏幕顶部的像素数
 
left=#
 窗口左端离开屏幕左端的像素数
 
width=#
 窗口的宽度
 
height=#
 窗口的高度
 
menubar=...
 窗口有没有菜单,取值yes或no
 
toolbar=...
 窗口有没有工具条,取值yes或no
 
location=...
 窗口有没有地址栏,取值yes或no
 
directories=...
 窗口有没有连接区,取值yes或no
 
scrollbars=...
 窗口有没有滚动条,取值yes或no
 
status=...
 窗口有没有状态栏,取值yes或no
 
resizable=...
 窗口给不给调整大小,取值yes或no
 

close() 关闭一个已打开的窗口。
window.close() 或 self.close():关闭本窗口;
<窗口对象>.close():关闭指定的窗口。
  如果该窗口有状态栏,调用该方法后浏览器会警告:“网页正在试图关闭窗口,是否关闭?”然后等待用户选择是否;如果没有状态栏,调用该方法将直接关闭窗口。

至于opener他应该是window的属性而非方法

 用法:window.opener;返回打开本窗口的窗口对象。注意:返回的是一个窗口对象。如果窗口不是由其他窗口打开的,在 Netscape 中这个属性返回 null;在 IE 中返回“未定义”(undefined)。undefined 在一定程度上等于 null。注意:undefined 不是 JavaScript 常数,如果你企图使用“undefined”,那就真的返回“未定义”了。

在这里就有个问题了,怎们后面说….(卖个关子)

OK, 窗口现在是打开了, 接下来我们想要做什么?

一, 在新的页面上得到一个或多个值, 之后传递下去?

这种情况下,JavaScript就不是唯一的最佳选择了, 虽然在传统的ASP当中form Post是上加之选,但在ASP.NET中就显得有些老土了,并且实现起来有些麻烦! ASP.NET为我们提供了多种方式,

QueryString,  Session,  Server.Transfer,  Cache,  ViewState

一种是可以通过用来传送相应的值,再一种是通过变量来传送相应的值,还有就是通过方法来实现。下面分别一一介绍:  

1. Querystring  (较古老)

Querystring是一种非常简单的传值方式,其缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象。还有就是URL需要自行设计,容易出错. 不过如果你想传递一个安全性不是那么太重要或者是一个简单的数值时,用此方法还是可取的。

简单的例子就是在父级页面中
 string  url; 
 url="webform2.aspx?name="  +   
   TextBox1.Text  +  "&email="  +   
   TextBox2.Text; 
 Response.Redirect(url); 

在第二个页面的page_load中加入

 Label1.Text=Request.QueryString["name"]; 
 Label2.Text=Request.QueryString["email"];
运行,即可看到传递后的结果了。

 

2. Session 
 使用Session变量传值是一种最常见的方式了,此中方式不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed后,变量才会消失。不过问题是,两个页面之间最好还是使用局部变量。否则可能会有项目组中Session命名冲突的问题。再就是记得用完后remove掉.

简单的例子就是在父级页面中加入
Session["name"]=TextBox1.Text; 
 Session["email"]=TextBox2.Text; 
 Response.Redirect("webform2.aspx"); 
在第二个页面的page_load中加入

 Label1.Text=Session["name"].ToString(); 
 Label2.Text=Session["email"].ToString(); 
 Session.Remove("name"); 
 Session.Remove("email"); 
运行,即可看到传递后的结果了。 

 

3. Server.Transfer 
虽然这种方法有点复杂,但也不失为一种在页面传值的方式。Server.Transfer的方法居然有很多人说好,这种方法要求被调用的页面去引用调用的页面,这种方法明显违反编程的原则。原来被调用的页面可以独立使用,可以被其他页面调用,用了这种方法就不行了!没有深度研究, 就不显摆了. 

 

4. Cache
在ASP.NET页面和ASP.NET用户控件(动态装入)之间传递数据时.在ASP.NET页面中装入用户控件的时候
Cache[“Test“] =“Test“
在用户控件的Page_Load方法中:
Label1.Text  = Page.Page.Cache[“Test“].ToString;
Label1应该显示为“Test”

5. ViewState
ViewState适用在一个页面中保存状态,要在两个页面之间使用似乎也不行。(没有深度研究)

二, 在新的页面上得到一个或多个值后,传回父级页面?

这个问题在我看来,JavaScript是个不二之选,

在父级页面中

<head runat="server">中添加

<script type='text/javascript'>

function openWindow()  

 {  

window.open('Popup.aspx','_blank','height=450,width=470,status=no,toolbar=no,menubar=no,scrollbars=no,location=no');

}

</script>

<form id="form1" runat="server">中添加

<div>

   <asp:TextBox ID="TB_subject" runat="server"></asp:TextBox>

   <asp:TextBox ID="TB_Infor" runat="server"></asp:TextBox>

   <p>

   <input type="button" value="传值并返回父窗口" name="button1" onclick="popup()" /></p>

</div>

当然也可以写在code里,写法如下

Dim PopUpDialog As String

        PopUpDialog = "<script type='text/javascript'>window.open('Popup.aspx','_blank','height=450,width=470,status=no,toolbar=no,menubar=no,scrollbars=no,location=no');</script>"

        ScriptManager.RegisterStartupScript(Me, Me.GetType, "key", PopUpDialog, False)

PopUp页面当中

<head runat="server">中添加

 <script type="text/javascript">

 function popup()  

 {  

      window.opener.document.getElementById("TB_subject").value=document.getElementById("TB_Name").value;

      window.opener.document.getElementById("TB_Info").value=document.getElementById("TB_Summary").value;

      window.close()    

     }

</script>

<form id="form1" runat="server">中添加

<div>

   <asp:TextBox ID="TB_Name" runat="server"></asp:TextBox>

   <asp:TextBox ID="TB_Summary" runat="server"></asp:TextBox>

   <p>

   <input type="button" value="传值并返回父窗口" name="button1" onclick="popup()" /></p>

</div>

之后在触发对象(input,button etc…)上添加onclick="popup()" 事件即可, 当然在ASP.NET中如果应用了VB或C#Code这句话应当改为OnClientClick="popup()".

好了解释一下前面卖的关子,这里需要注意几个问题,

1.        window.opener.document.getElementById("TB_Name").value这句话虽然可以用window.opener.document.all["TB_Name"].value代替,但是它只对IE有效,在firefox中或其他浏览器是没有结果的,因为事实上document没有all这个方法getElementById或getElementByName才是正解.

2.        如果使用了ASP.NET 2.0 AJAX, 并且把xhtml tag对象写入Code的时候,记得用ScriptManager.RegisterStartupScript(Me, Me.GetType, "key", PopUpDialog, False) 替代Response.Write(script); 因为在ScriptManager控件里不支持Response.Write()


本文来自优快云博客,转载请标明出处:http://blog.youkuaiyun.com/coomon2000/archive/2008/10/21/3118309.aspx

在 Layui 框架中,`layer.open` 方法用于创建弹出层,可以通过多种方式递参数。以下是几种常见的参数递方法: ### 1. 使用 `data` 参数传递数据 可以在 `layer.open` 的配置中直接使用 `data` 属性来传递数据,子页面可以直接通过 `parent` 对象访问这些数据[^2]。 ```javascript function layer_show(title, url, data, w, h) { if (title == null || title == '') { title = false; } if (url == null || url == '') { url = "404.html"; } if (w == null || w == '') { w = 800; } if (h == null || h == '') { h = ($(window).height() - 50); } layer.open({ type: 2, area: [w + 'px', h + 'px'], fix: false, // 不固定 maxmin: true, shade: 0.4, title: title, data: data }); } ``` 子页面中可以这样获取递的数据: ```javascript var data = parent.data; ``` ### 2. 通过 URL 查询字符串递参数 另一种常见的方式是将参数附加到 URL 上作为查询字符串,然后在子页面中解析这些参数。 ```javascript layer.open({ type: 2, area: ['800px', '600px'], content: url + '?data=' + encodeURIComponent(JSON.stringify(data)) }); ``` 子页面中可以使用如下代码来解析 URL 中的参数: ```javascript function getParameterByName(name) { name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]"); var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"), results = regex.exec(location.search); return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " ")); } var data = JSON.parse(getParameterByName('data')); ``` ### 3.窗口向父窗口 如果需要从子窗口向父窗口传递数据,可以通过操作父窗口的 DOM 元素或者调用父窗口的方法来实现[^4]。 子窗口中设置父窗口的输入框: ```javascript function btnBack() { $("#cz", window.parent.document).val('2'); // 给父窗口 var index = parent.layer.getFrameIndex(window.name); parent.layer.close(index); // 关闭子窗口 } ``` 父窗口中可以在 `end` 回调中处理接收到的数据: ```javascript end: function () { var cz = $("#cz").val(); if (cz == '2') { document.getElementById('cz').value = '1'; return false; } } ``` ### 4. 使用回调函数递结果 当关闭弹出层时,可以通过回调函数递结果回父窗口[^3]。 ```javascript layer.open({ type: 0, skin: "layui-layer-molv", title: "信息", content: data.code == 1 ? "添加成功!" : "添加失败!", btn: ['返回列表'], yes: function () { let index = parent.layer.getFrameIndex(window.name); parent.layui.table.reload('news_table'); // 重载父页表格,参数为表格ID parent.layer.close(index); } }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值