zoukankan
html css js c++ java
asp.net中窗口相关操作总结(javascript)
这些代码全部写在和页面分离的代码页中(codebehind),如果要嵌入到*.aspx页面,可能
会出现问题.
1.打开新窗口
这个简单:Response.Write(@"
<
script
language
='javascript'
>
window.open('url');
</
script
>
");
2.关闭窗口
//关闭当前窗口,并提示用户时候关闭,yes关闭,no退出
Response.Write(@"
<
script
language
='javascript'
>
window.close();
</
script
>
");
//延迟关闭窗口(下面代码表示2秒后关闭,无需确认)
Response.Write(@"
<
script
language
='javascript'
>
setTimeout('self.close()',
2000
);
</
script
>
");
3.延迟时间
这个和上面的没有多少区别.我用到的情况是,在用户操作完毕给出提示,"n秒后,页面
转向"之类的只需去掉2重的Self.close()即可
Response.Write(@"
<
script
language
='javascript'
>
setTimeout('',
2000
);
</
script
>
");
4.弹出提示或警告窗口
Response.Write(@"
<
script
language
='javascript'
>
alert('添加成功,2秒钟后页面
将自动跳');
</
script
>
");
5.刷新其他页面
这个用到的情况还是不少.比如在B页面对数据更新和修改,另一页面A要保持最新数据
给客户,这是就要在对B操作完毕的情况下对A进行刷新:
Response.Write(@"
<
script
language
='javascript'
>
window.opener.location.
href
=
'.
/
default
.aspx'
</
script
>
") ;
6.页面跳转
有时候在学要给出提示的情况下进行页面跳转,不能使用Response.Redirect("url");
比如,当客户操作完毕,单击按钮提交,弹出提示框(使用上面3和4),如果使用了
Response.Redirect("url");
那么页面将不给出提示,页就是3和4没有起作用就直接转向了.
如果你是下面的操作过程:
1).Response.Write(@"
<
script
language
='javascript'
>
alert('添加成功,2秒钟后页
面将自动跳');
</
script
>
");
2).Response.Write(@"
<
script
language
='javascript'
>
setTimeout('',
2000
);
</
script
>
");
3).页面转向:
Response.Write("
<
meta
http-equiv
='refresh'
content
='0;URL=./default.aspx'
>
");
//这个我不知道用javascript怎么实现,熟悉的轻补充一下
7.窗口传制问题
这个问题比较烦,打开模态窗口(ShowModelDialog)我还没有实现,请各位补充.
具体情况是这样的,比如说A打开一个新窗口B,当用户对B操作完毕后,我们获得必要的
数据,自动将其赋给A中的TextBox等控件,这个过程是在客户端完成的.就像发送邮件时,
需要从地址本中选取,然后将选中的发送地址传回来.
1).在A中加入如下代码,打开一个新窗口B.
Response.Write(window.">@"window.
open('B.aspx','','toolbar=no,menubar=no,status=yes,location=no,
resizable=no,scrollbars=no,width=500,height=350');
</
script
>
");
2).对B操作完毕,获得必要数据tmpStr,然后将其赋值给A中的TextBox1
Response.Write(@"
<
script
language
='javascript'
>
opener.document.all.TextBox1.value
=
'
"
+tmpStr+
"
';
</
script
>
");
注意:这个过程是在客户单用javascript完成的,因此我们不能按照服务端的编程习惯
以及不能使用web服务控件的服务端属性进行操作.TextBox1是一个web服务控件,
其id为TextBox1,A页面被服务器解析为html,通过浏览器浏览,TextBox1就变成了
纯html控件,我们这里用javascript操作的也就是html控件,因此赋值使用的是
TextBox1的value属性而不是Text属性.另外,web服务器控件的id被解析成html后,
id有时会变,我们只要注意使用服务器解析后的id就成了,在浏览器中右键->查看源文件
即可得到
对第七种操作情况最好使用打开模态窗口windows.ShowModelDialog(),但是比较麻烦,
哦还没有实现.
接上:
调整本窗口大小和位置
Response.Write("
<
script
>
window.resizeTo(
500
,
400
);
</
script
>
");
Response.Write("
<
script
>
window.moveTo(
300
,
200
);
</
script
>
");
接上:
补:使用模态窗口传值
主要代码如下:
a.aspx and a.aspx.cs
<%
@ Page language
=
"
c#
"
Codebehind
=
"
a.aspx.cs
"
AutoEventWireup
=
"
false
"
Inherits
=
"
Genesis02.a
"
%>
<
HTML
>
<
HEAD
>
<
title
>
a
</
title
>
<
SCRIPT
language
="javascript"
>
var
str;
function
pop(url)
{
var
myDialog
=
document.a.TBoxType.value;
if
(window.showModalDialog)
{
str
=
window.showModalDialog(url,myDialog,
"
dialogHeight:
300px; dialogWidth: 500px;center: yes; help: no;resizable: yes; status:
no;
"
);
if
(
typeof
(str)
!=
"
undefined
"
)
{
document.a.TBoxType.value
=
str;
}
}
}
</
SCRIPT
>
</
HEAD
>
<
body
MS_POSITIONING
="GridLayout"
>
<
form
id
="a"
method
="post"
runat
="server"
>
<
asp:textbox
id
="TBoxType"
runat
="server"
></
asp:textbox
><
asp:button
id
="BtnGetType"
Runat
="server"
Text
="Open"
></
asp:button
>
</
form
>
</
body
>
</
HTML
>
__________________________________________________________________
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace Genesis02
{
///
<
summary
>
/// a 的摘要说明。
///
</
summary
>
public class a : System.Web.UI.Page
{
protected System.Web.UI.WebControls.TextBox TBoxType;
protected System.Web.UI.WebControls.Button BtnGetType;
private void Page_Load(object sender, System.EventArgs e)
{
if (!IsPostBack)
{
BtnGetType.Attributes["onclick"] = "pop('c.aspx');return
false;";
}
}
#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
///
<
summary
>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
///
</
summary
>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}
#################################################################
b.aspx and b.aspx.cs
<%
@ Page language
=
"
c#
"
Codebehind
=
"
b.aspx.cs
"
AutoEventWireup
=
"
false
"
Inherits
=
"
Genesis02.b
"
%>
<
HTML
>
<
HEAD
>
<
title
>
b
</
title
>
<
SCRIPT
language
="javascript"
>
function
closeme()
{
//
top.returnvalue =
window.document.all.LBoxRFAContent.options[window.document.all.LBoxRFAContent
.selectedindex].value;
top.returnvalue
=
document.getElementById(
"
TBoxvalue
"
).value;
top.close();
}
function
Body_Load()
{
if
(window.dialogArguments
!=
null
)
{
window.document.getElementById(
"
TBoxvalue
"
).value
=
window.dialogArguments;
}
}
</
SCRIPT
>
</
HEAD
>
<
body
MS_POSITIONING
="GridLayout"
onload
="Body_Load()"
>
<
form
id
="b"
method
="post"
runat
="server"
>
<
asp:Button
id
="BtnClose"
style
="Z-INDEX: 101; LEFT: 152px;
POSITION: absolute; TOP: 131px"
runat
="server"
Text
="Close me"
></
asp:Button
>
<
asp:TextBox
id
="TBoxvalue"
style
="Z-INDEX: 102; LEFT: 149px;
POSITION: absolute; TOP: 69px"
runat
="server"
></
asp:TextBox
>
</
form
>
</
body
>
</
HTML
>
__________________________________________________________________
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace Genesis02
{
///
<
summary
>
/// b 的摘要说明。
///
</
summary
>
public class b : System.Web.UI.Page
{
protected System.Web.UI.WebControls.TextBox TBoxvalue;
protected System.Web.UI.WebControls.Button BtnClose;
private void Page_Load(object sender, System.EventArgs e)
{
if (!IsPostBack)
{
BtnClose.Attributes["onclick"] = "closeme();return false;";
}
}
#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
///
<
summary
>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
///
</
summary
>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}
#######################################################################
c.aspx and c.asp.cs
<%
@ Page language
=
"
c#
"
Codebehind
=
"
c.aspx.cs
"
AutoEventWireup
=
"
false
"
Inherits
=
"
Genesis02.c
"
%>
<
HTML
>
<
HEAD
>
<
TITLE
>
c
</
TITLE
>
</
HEAD
>
<
frameset
rows
="0,*"
>
<
frame
src
="about:blank"
>
<
frame
src
="b.aspx"
>
</
frameset
>
</
HTML
>
____________________________________________________
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace Genesis02
{
///
<
summary
>
/// c 的摘要说明。
///
</
summary
>
public class c : System.Web.UI.Page
{
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
}
#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
///
<
summary
>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
///
</
summary
>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}
#############################################################################
c.aspx and c.asp.cs
<%
@ Page language
=
"
c#
"
Codebehind
=
"
c.aspx.cs
"
AutoEventWireup
=
"
false
"
Inherits
=
"
Genesis02.c
"
%>
<
HTML
>
<
HEAD
>
<
TITLE
>
c
</
TITLE
>
</
HEAD
>
<
frameset
rows
="0,*"
>
<
frame
src
="about:blank"
>
<
frame
src
="b.aspx"
>
</
frameset
>
</
HTML
>
____________________________________________________
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace Genesis02
{
///
<
summary
>
/// c 的摘要说明。
///
</
summary
>
public class c : System.Web.UI.Page
{
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
}
#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
///
<
summary
>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
///
</
summary
>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}
查看全文
相关阅读:
javascript异步编程学习及实例
通过调试vue-cli 构建代码学习vue项目构建运行过程
web技术栈开发原生应用-多端共用一套代码
vuejs应用开发前后端分离
web前端跨域解决方案JSONP,CORS,NGINX反向代理
js script 加载顺序
js 百度地图
layui-table 样式
css 排版 test
layui table
原文地址:https://www.cnblogs.com/ghd258/p/330853.html
最新文章
SAP WDA 自建Portal
SAP跳过权限检查/前提是有debug权限
PI接口开发之调java WS接口
get UI URL
UI 增加文本
ALV基础二:ALV的扩展功能
想整理点东西
SAP 多语言文本翻译
CRM INBOX 查询结果增强字段
CRM INBOX 结果增强功能
热门文章
ZCRM_AU_MAIL
CRM SALES ORDER ADD EEWB SEARCH FIELD
PI上导入RFC
ABAP基础一:ALV基础之ALV的整体结构
^_^函数创建用户并分配权限
再谈初学者关心的ssh应用方方面面
彻底理解javascript中的this指针
Static and Instance Methods in JavaScript
vue/react/angular开发的css架构思考
webpack等bundler是如何工作的-简化版本
Copyright © 2011-2022 走看看