如何点击按钮弹出新窗口,输入数据后返回并刷新页面?

如何点击按钮弹出新窗口,输入数据后返回并刷新页面?
作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2003年7月8日 4点0分13秒

在一些.NET论坛中有人经常会问:如何在页面中点击按钮打开新页面,输入数据,然后返回到初始页面并进行更新?要解决这个问题,应该弄清楚window.showModalDialog()的用法,本人在http://www.csdn.net/Develop/read_article.asp?id=15113已经做过介绍。下面就用例子介绍如何在ASP.NET中实现这个功能。

本例子共3个页面,其中WebForm2.aspx是过渡页面,是为了防止提交时打开新页面。

WebForm1.aspx

      <FONT size=3><FONT size=4><%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm1.aspx.vb" Inherits="ShowModalDialog.WebForm1" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <title>WebForm1</title> <meta content="Microsoft Visual Studio .NET 7.0" name="GENERATOR"> <meta content="Visual Basic 7.0" name="CODE_LANGUAGE"> <meta content="JavaScript" name="vs_defaultClientScript"> <meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema"> </HEAD> <body MS_POSITIONING="GridLayout"> <div align="center"> <form id="Form1" method="post" runat="server"> <asp:label id="Label1" runat="server" Font-Bold="true"> 从当前页面打开新窗口,并把变量传递到新窗口的例子,可以多次打开提交。 </asp:label><br> <br> <asp:textbox id="TextBox1" runat="server" Width="600px">这是初始值,将被传递到新窗口。</asp:textbox><br> <br> <asp:button id="Button1" runat="server" Text="打开窗口" Width="96px"></asp:button></form> </div> </body> </HTML> </FONT></FONT> 
    

WebForm1.aspx.vb

      <FONT size=3><FONT size=4>Public Class WebForm1 Inherits System.Web.UI.Page Protected WithEvents TextBox1 As System.Web.UI.WebControls.TextBox Protected WithEvents Form1 As System.Web.UI.HtmlControls.HtmlForm Protected WithEvents Label1 As System.Web.UI.WebControls.Label Protected WithEvents Button1 As System.Web.UI.WebControls.Button</FONT> #Region " Web 窗体设计器生成的代码 " '该调用是 Web 窗体设计器所必需的。 <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent() End Sub Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init 'CODEGEN: 此方法调用是 Web 窗体设计器所必需的 '不要使用代码编辑器修改它。 InitializeComponent() End Sub #End Region Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load '在此处放置初始化页的用户代码 If (Not IsClientScriptBlockRegistered("clientScript")) Then Dim strScript As String = "<script>" + vbCrLf strScript += "function OpenWin(){" + vbCrLf strScript += "var str=window.showModalDialog('WebForm2.aspx',document.Form1.TextBox1.value)" + vbCrLf strScript += "if(str!=null) document.Form1.TextBox1.value=str" + vbCrLf strScript += "}" + vbCrLf strScript += "</script>" + vbCrLf RegisterClientScriptBlock("clientScript", strScript) End If Button1.Attributes.Add("onclick", "OpenWin()") End Sub End Class </FONT> 
    

WebForm2.aspx

      <FONT size=4><%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm2.aspx.vb" Inherits="aspxWeb.mengxianhui.com.WebForm2"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <title>WebForm2</title> <meta name="GENERATOR" content="Microsoft Visual Studio .NET 7.0"> <meta name="CODE_LANGUAGE" content="Visual Basic 7.0"> <meta name="vs_defaultClientScript" content="JavaScript"> <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5"> </HEAD> <frameset rows="0,*"> <frame src="about:blank"> <frame src="WebForm3.aspx"> </frameset> </HTML> </FONT> 
    

WebForm2.aspx.vb

      <FONT size=4>Public Class WebForm2 Inherits System.Web.UI.Page #Region " Web 窗体设计器生成的代码 " '该调用是 Web 窗体设计器所必需的。 <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent() End Sub Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init 'CODEGEN: 此方法调用是 Web 窗体设计器所必需的 '不要使用代码编辑器修改它。 InitializeComponent() End Sub #End Region Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load '在此处放置初始化页的用户代码 End Sub End Class </FONT> 
    

WebForm3.aspx

      <FONT size=4><%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm3.aspx.vb" Inherits="ShowModalDialog.WebForm3" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <title>WebForm3</title> <meta name="GENERATOR" content="Microsoft Visual Studio .NET 7.0"> <meta name="CODE_LANGUAGE" content="Visual Basic 7.0"> <meta name="vs_defaultClientScript" content="JavaScript"> <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5"> </HEAD> <body MS_POSITIONING="GridLayout" id="MyBody" runat="server"> <form id="Form1" method="post" runat="server"> <asp:Label id="Label1" runat="server">请输入您的大名:</asp:Label><br> <br> <asp:TextBox id="TextBox1" runat="server" Width="558"></asp:TextBox><br> <br> <asp:Button id="Button1" runat="server" Text=" 提 交 "></asp:Button> </form> </body> </HTML> </FONT> 
    

WebForm3.aspx.vb

      <FONT size=4>Public Class WebForm3 Inherits System.Web.UI.Page Protected WithEvents TextBox1 As System.Web.UI.WebControls.TextBox Protected WithEvents Label1 As System.Web.UI.WebControls.Label Protected WithEvents Button1 As System.Web.UI.WebControls.Button Protected MyBody As System.Web.UI.HtmlControls.HtmlControl #Region " Web 窗体设计器生成的代码 " '该调用是 Web 窗体设计器所必需的。 <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent() End Sub Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init 'CODEGEN: 此方法调用是 Web 窗体设计器所必需的 '不要使用代码编辑器修改它。 InitializeComponent() End Sub #End Region Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load '在此处放置初始化页的用户代码 If IsPostBack Then Dim strScript As String = "<script>" + vbCrLf strScript += "window.parent.returnValue='" + TextBox1.Text.Replace("'", "/'") + "'" + vbCrLf strScript += "window.parent.close()" + vbCrLf strScript += "</script>" + vbCrLf If (Not IsClientScriptBlockRegistered("clientScript")) Then RegisterClientScriptBlock("clientScript", strScript) End If End If If Not IsPostBack Then MyBody.Attributes.Add("onload", "document.Form1.TextBox1.value=window.parent.dialogArguments") End If End Sub End Class</FONT> 
    
  本文评论(Comments):为了保护您的电子邮件不被骚扰,地址中的个别符号转换成了全角字符!
 评论人:huoqiming电子邮件:huoqiming@sohu.com评论日期:2004年09月09日 09:40:07
 孟老师: 如何把子窗口中的值传到父窗口中用户控件中的文本框中?
 评论人:wxk666电子邮件:wxiangk666@yahoo.com.cn评论日期:2004年08月21日 12:00:24
 好,vb代码我喜欢
 评论人:大木鸟电子邮件:aspx888@163.com评论日期:2004年08月10日 02:55:41
 vb.net好啊支持!
 评论人:andfor电子邮件:andfor007@126.com评论日期:2004年08月03日 07:47:17
 study
 评论人:and 电子邮件:a 评论日期:2004年08月03日 07:46:43
 study
 评论人:xi_wi电子邮件:xi_wi◎lycos.com评论日期:2004年07月30日 09:37:37
 点击第三个页面,关闭不了它,不会向第一页面返回值。(C#)
 评论人:电子邮件:photoandimagelin@163.com评论日期:2004年07月22日 03:11:55
 好哦
 评论人:电子邮件:评论日期:2004年07月12日 10:04:04
 private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
string vbCrLf="/n";
if (IsPostBack)
{
string strScript= " <script>" + vbCrLf;
strScript += "window.parent.returnValue='" + TextBox1.Text.Replace("'", "/'") + "'" + vbCrLf;
strScript += "window.parent.close()" + vbCrLf;
strScript += "</script> " + vbCrLf;
if (! IsClientScriptBlockRegistered("clientScript")) 
RegisterClientScriptBlock("clientScript", strScript);

if (!IsPostBack)
MyBody.Attributes.Add("onload", "document.Form1.TextBox1.value=window.parent.dialogArguments");
}
}
 评论人:九品电子邮件:评论日期:2004年07月12日 10:02:51
 
public class getpass : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label1;
protected System.Web.UI.WebControls.TextBox TextBox1;
protected System.Web.UI.WebControls.Button Button1;
protected System.Web.UI.WebControls.Button Button2;
protected System.Web.UI.HtmlControls.HtmlControl MyBody;

private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
string vbCrLf="/n";
if (IsPostBack)
{
string strScript= " <script>" + vbCrLf;
strScript += "window.parent.returnValue='" + TextBox1.Text.Replace("'", "/'") + "'" + vbCrLf;
strScript += "window.parent.close()" + vbCrLf;
strScript += "</script> " + vbCrLf;
if (! IsClientScriptBlockRegistered("clientScript")) 
RegisterClientScriptBlock("clientScript", strScript);

if (!IsPostBack)
MyBody.Attributes.Add("onload", "document.Form1.TextBox1.value=window.parent.dialogArguments");
}
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// 
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// 

private void InitializeComponent()
{    
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
 评论人:电子邮件:评论日期:2004年07月10日 09:30:03
 http://dotnet.aspx.cc/ShowDetail.aspx?id=49ML4AO8-5PB3-4KNY-NJZD-LJOIOXV4M1X4
 评论人:hsb电子邮件:hsb0307@msn.com评论日期:2004年07月07日 04:49:38
 谁成功使用过,我怎么点击WebForm3的Button1关不了这个弹出窗口,我写了如下代码:
Button1.Attributes.Add("onclick", "javascript:parent.close();");
或者
Button1.Attributes.Add("onclick", "javascript:close();");

也不行,不能返回值给WebForm1上的控件,请成功使用过的,给解决一下。
 评论人:hsb电子邮件:黑死病评论日期:2004年07月07日 04:49:13
 谁成功使用过,我怎么点击WebForm3的Button1关不了这个弹出窗口,我写了如下代码:
Button1.Attributes.Add("onclick", "javascript:parent.close();");
或者
Button1.Attributes.Add("onclick", "javascript:close();");

也不行,不能返回值给WebForm1上的控件,请成功使用过的,给解决一下。
 评论人:gpyzy电子邮件:gpyzy@hotmail.com评论日期:2004年06月19日 01:49:10
  大力支持孟老大多多发布vb.net的代码:)
 评论人:dulker电子邮件:dulker@sina.com评论日期:2004年06月16日 12:00:30
 ?好象VB的代码居多,C#的呢
 评论人:czh电子邮件:pzczhhw@163.com评论日期:2004年06月06日 07:10:05
 孟老师,能不能麻烦将这段程序的运行机制说一下?主要是页面之间的传递。
 评论人:本站管理员电子邮件:评论日期:2004年05月27日 05:25:12
 注意:<base target=_self>在IE5下无效。
 评论人:本站管理员电子邮件:评论日期:2004年05月27日 05:24:31
 注意: 在IE5下无效。
 评论人:ssphoenix电子邮件:s_phoenix@tom.com评论日期:2004年04月02日 07:07:14
 sorry,看见了.
 评论人:ssphoenix电子邮件:s_phoenix@tom.com评论日期:2004年04月02日 07:05:24
 有错吧?
Button1.Attributes.Add("onclick", "OpenWin()")
可是页面上并没有定义OpenWin()这个函数呀?
 评论人:liuyu202电子邮件:liuyu202@etang.com评论日期:2004年03月29日 08:58:31
 Inherits="aspxWeb.mengxianhui.com.WebForm2"
是什么?

WebForm2.aspx有错误!如下:
未能加载类型:"VbWebApp.Global"

VbWebApp为应用程序名称!

 评论人:电子邮件:评论日期:2004年03月19日 09:17:44
 可以用事件@ 
 评论人:bruce_wang电子邮件:bruce_wang@163.com评论日期:2004年03月16日 11:17:59
 我已经转为C#了。VB.Net转C#很容易的。vbCrLf = /n。
 评论人:dsjfkf电子邮件:评论日期:2004年03月12日 02:54:16
 用的vbScript
 评论人:电子邮件:评论日期:2004年03月12日 02:48:55
 用的vbScript。
 评论人:lswallow电子邮件:lswallow_163@163.net评论日期:2004年03月03日 10:24:07
 这些代码我试了一下,好像有问题。
c#的代码有吗?
 评论人:nowfox电子邮件:nowfox@tom.com评论日期:2004年02月27日 01:09:18
 更希望要C#的代码
 评论人:yzwuxin电子邮件:yzwx007@sina.com评论日期:2004年02月24日 10:37:05
 换行
 评论人:chy电子邮件:chenhaoying@sohu.com评论日期:2004年02月09日 12:01:27
 代码中的vbCrlf是什么啊?
有c#代码吗?
 评论人:melancholy电子邮件:aking83@msn.com评论日期:2004年01月05日 01:27:08
 Easy....


 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用Ajax实现让txt文本在页面上出的步骤如下: 1. 在HTML页面中,首先需要有一个按钮或者触发事件的元素,用来触发Ajax请求。 2. 给该按钮或者触发事件的元素添加点击事件,当点击触发时,调用Ajax请求的函数。 3. 在Ajax请求的函数中,使用XMLHttpRequest对象创建一个新的请求。 4. 设定请求的方法和请求的URL,以及是否异步。 5. 当请求状态改变时(onreadystatechange事件触发),使用responseText属性获取服务器返回数据。 6. 创建一个HTML元素(如div或者p标签)来输入文本,将获取的文本数据作为该元素的内容。 7. 将该HTML元素添加到页面的特定位置,使其在页面上出。 8. 如果需要,可以对出的输入文本进行样式设置,让它更加美观。 总结:使用Ajax可以通过异步请求获取服务器返回的txt文本数据,并将它以出的形式展示在页面上。以上述步骤为基本框架,可以根据具体需求进行修改和补充。 ### 回答2: 要实现ajax输入文本,首先需要在页面上定义一个文本输入框和一个按钮。当用户点击按钮时,通过ajax请求将输入的文本发送到服务器端进行处理,并将服务器返回的结果显示在页面上。 具体步骤如下: 1. 在页面上定义一个文本输入框和一个按钮,用于用户输入文本和触发ajax请求。 2. 使用JavaScript监听按钮的点击事件,当按钮被点击时获取输入框中的文本内容。 3. 使用ajax发送POST请求到服务器端,将输入的文本内容作为数据传递给服务器。 4. 服务器端接收到数据后进行处理,例如保存到txt文件中。 5. 服务器端处理完成后,将结果返回给ajax请求的回调函数。 6. 在ajax的回调函数中,将服务器返回的结果显示在页面上,可以使用窗口或者动态添加元素等方式进行展示。 总结起来,ajax输入文本的实现主要涉及到前端与后端的交互,通过ajax将用户输入的文本发送到服务器进行处理,并将处理结果返回给前端进行展示。这样就实现了在页面上出txt文本的功能。 ### 回答3: Ajax是一种在不刷新整个页面的情况下,通过与服务器进行异步通信来更新部分页面的技术。它可以通过与服务器交换数据,在不打断用户操作的情况下,将数据动态加载到当前页面上。 对于“ajax输入文本”,这个功能可以通过以下步骤实现: 1. 在页面上创建一个按钮或链接,用于触发输入文本的操作。 2. 使用JavaScript编写一个函数,用于处理按钮或链接的点击事件。 3. 在该函数中,使用Ajax发送一个请求到服务器,请求返回一个包含输入文本的窗口。 4. 服务器接收到请求后,根据请求参数处理逻辑,并生成一个包含输入文本的页面内容。 5. 服务器返回响应,将窗口页面的内容发送到客户端。 6. 客户端接收到服务器的响应后,将响应内容添加到当前页面中的一个元素中(如一个div)。 7. 窗口页面的内容将在该元素中显示,从而实现了在页面上输入文本。 需要注意的是,这只是基本的步骤,具体实现还需要根据具体的需求和技术栈进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值