分享
 
 
 

ASP.NET1.0/2.0里用DIV层元素弹出窗体

王朝asp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

本文 Bilal Haidar 将带领您如何使用DIV元素来创建弹出的窗体,这种弹出即可以包含简单的HTML元素也可以包含asp.net服务器控件,而且在实现过程中没有使用传统的window函数和showModalDialog / showModelessDialog函数(传统的我们使用 window.open,或者showModalDialog 这样的函数来制作弹出窗口--天天注释)

最近我在用ASP.NET1.1技术来开发一个窗体,该窗体包含由三个控件组成的一个面板集合,这个面板用来显示系统信息.可以假想这些控件是一些简单的下拉框,当第一个下拉框选取后,第二个下拉框的值将显示被第一个过滤的结果,同样第三个下拉框将根据第二个下拉框的选择而进行改变显示。

窗体的这个技术通常被用来让终端客户那些不知道ASP.NET技术的人员获取更好的用户体验。

当决定使用这些控件的替代品使用时,您是否用过dropdownlist或者是具有弹出窗体功能的Textbox控件?

好了,我们已经有了一个很好的解决方案:使用TextBox控件并挂钩OnClick事件来触发DIV弹出窗体,包括使用Listbox控件来选择数据的值

一个不使用任何常规popup窗体或者过时的Dropdownlist来完成这个功能

THE HTML WebForm

我们已经建立了一个简单的WebForm,他包含了一些TextBox,每一个TextBox已经附加了OnClick事件,用一段javascript代码来弹出窗体,代码如下:

<%@ Page language="c#"

Codebehind="ParentPage.aspx.cs" AutoEventWireup="false"

Inherits="PopupWithDiv.ParentPage" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >

<HTML>

<HEAD>

<title>Parent Page</title>

<LINK href="main.CSS" type="text/css" rel="stylesheet">

<script src="jspopup.js" type="text/Javascript"></script>

<script language="javascript">

<!--

// PRevent users from typing any text

// into the Textbox

function ProtectBox(e)

{return false; }

//-->

</script>

</HEAD>

<body>

<form id="Form1" method="post" runat="server">

<!-- Header Section -->

<div id="header">

<p>Popup Window with DIV Layer</p>

</div>

<!-- Body Section -->

<div id="content">

<table border="0" cellpadding="0" cellspacing="0">

<tr valign="top">

<td><label for="txtCountry">Country :</label></td>

<td><asp:TextBox

id="txtCountry" runat="server" OnKeyDown="return

ProtectBox(event);" OnClick="PopupArea(event, 'divCountry')"></asp:TextBox></td>

<td width="50"></td>

<td><label for="txtCity">City :</label></td>

<td><asp:TextBox

id="txtCity" runat="server" OnKeyDown="return

ProtectBox(event);" OnClick="PopupArea(event, 'divCity')"></asp:TextBox></td>

</tr>

</table>

</div>

<%-- Country --%>

<div class="popupWindow" id="divCountry">

<table cellSpacing="0" cellPadding="0" width="100%"bgColor="#2557ad" border="0">

<tr>

<td align="right"><span style="CURSOR: hand"

onclick="jsAreaClose('divCountry')"><img alt="Hide Popup" src="close.gif"

border="0"></span></td>

</tr>

<tr>

<td>

<asp:ListBox id="lstCountry" runat="server" AutoPostBack="True" width="100%"

rows="10"></asp:ListBox></td>

</tr>

</table>

</div>

<%-- City --%>

<div class="popupWindow" id="divCity">

<table

cellSpacing="0" cellPadding="0" width="100%"

bgColor="#2557ad" border="0">

<tr>

<td align="right"><span style="CURSOR: hand" onclick="jsAreaClose('divCity')"><img alt="Hide Popup" src="close.gif" border="0"></span></td>

</tr>

<tr>

<td>

<asp:ListBox id="lsCity" runat="server" AutoPostBack="True" width="100%" rows="10"></asp:ListBox></td>

</tr>

</table>

</div>

</form>

</body>

</HTML>

代码中,用粗体标出的部分是Popup窗体的主要属性,在鼠标单击时,将调用一端JavaScript:PopupArea。

正如您所看到的,我们在页面底部添加了两个DIV元素,一个用于国家,一个用于城市,每一个都包含ListBox控件,用户可以使用Listbox选择上面的内容。

下图1现实了页面浏览的效果,他还演示了如何弹出DIV窗体

当单击Textbox内部,windows将弹出窗体而不会引起页面数据回发现在该到填充其中数据的时候了

Page COde-behind

在页面后台,我们准备从一个xml文档加载list“国家”所需要的数据,同时显示国家的名称,下面列出了这个功能的代码:

Listing 2: Populate Country ListBox

// Load data into Country List box

if (!Page.IsPostBack)

{

// Load data from XML into a DataSet

DataSet ds = new DataSet();

ds.ReadXml(Server.MapPath("countries.xml"));

this.lstCountry.DataSource = ds.Tables[0].DefaultView;

this.lstCountry.DataTextField = "name";

this.lstCountry.DataBind();

}

在这一步骤中,当页面运行时,您可以选择国家,如下图

现在,当用户选择国家时,将触发listbox的选择事件,并通过该事件加载“城市”数据,该数据同样从XML文档加载

下面列出了事件代码

Listing 3

private void lstCountry_SelectedIndexChanged(object sender, EventArgs e)

{

// Set the value in the textbox

this.txtCountry.Text = this.lstCountry.SelectedValue;

// Load and Filter the lstCity

DataSet ds = new DataSet();

ds.ReadXml(Server.MapPath("cities.xml"));

DataView dv = ds.Tables[0].DefaultView;

dv.RowFilter = "country = '" + this.lstCountry.SelectedValue + "'";

// Bind lstCity

this.lstCity.DataSource = dv;

this.lstCity.DataTextField = "name";

this.lstCity.DataBind();

}

用户现在可以选择与国家相匹配的城市,如下

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有