版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
本章要求:了解HTML服务器控件熟悉ASP.NET3.5标准控件熟练掌握控件的应用方式
第4章ASP.NET3.5标准控件1目录4.1ASP.NET3.5页面事件处理4.2ASP.NET3.5服务器控件概述4.3标准控件4.4小结24.1ASP.NET3.5页面事件处理Web
窗体的事件模型Web窗体事件的触发和响应过程控件的三大要素:属性、方法和事件34.1.1ASP.NET3.5事件
常用事件:
Page_Load事件:打开页面或重载页面时触发,
事件处理方法名与事件名相同。
(Page类中定义)
voidPage_Load(objectsender,EventArgse){}
sender
表示触发事件的对象,e包含事件信息
4Click事件被触发时一般会引起页面重新加载。voidSubmitButton_Click(objectsender,EventArgse){}Change事件被触发时,先将事件的信息暂时保存在客户端的缓冲区中,等到下一次向服务器传递信息时,再和其他信息一起发送给服务器。若要让控件的Change事件立即得到服务器的响应,就需要将该控件的属性AutoPostBack值设为true。voidTextBox1_TextChanged(objectsender,EventArgse){…}54.1.2属性IsPostBack
当控件的事件被触发时,Page_Load事件会在控件的事件之前被触发。如果想在执行控件的事件代码时不执行Page_Load事件中的代码,可以通过判断属性Page.IsPostBack实现。属性IsPostBack在用户第一次浏览网页时,会返回值false,否则返回值true。6实例4-1属性IsPostBack应用Page_Load事件和Click事件一起使用本实例在页面第一次载入时显示“页面第一次加载!”。当单击按钮时显示“执行Click事件代码!”。源程序:IsPostBack.aspx(P73)程序说明:当单击按钮时引起页面往返,此时首先处理Page_Load事件中代码,但因为“!IsPostBack”值为false,所以不执行“Response.Write(“页面第一次加载!”)”,然后处理Click事件中代码,显示“执行Click事件代码!”信息。7IsPostBack.aspx<body>
<formid="form1“runat="server">
<div>
<asp:ButtonID="Button1"
runat="server“OnClick="Button1_Click"
Style="font-size:x-large"Text="Button"/>
</div>
</form>
</body>8usingSystem;publicpartialclasschap4_IsPostBack:System.Web.UI.Page{
protectedvoidPage_Load(objectsender,EventArgse){if(!IsPostBack){Response.Write(“页面第一次加载!”);
//先显示}
}protectedvoidButton1_Click(objectsender,EventArgse){Response.Write("执行Click事件代码!");
}}IsPostBack.aspx.cs去掉if语句,观察运行结果94.2ASP.NET3.5服务器控件概述控件是网页设计的基础,在工具箱中,点击工具箱中的控件,拖动到设计窗口。HTML服务器控件:常用于升级原有的ASP页面到ASP.NET页面(标记变控件)。Web服务器控件:目前的ASP.NET3.5网站建设中,优先考虑Web服务器控件。当Web服务器控件无法完成特定的任务时,可考虑HTML服务器控件。104.2.1HTML服务器控件简介实现了将XHTML元素到服务器控件的转换。经过转换后,Web窗体页就可访问XHTML元素,从而实现在服务器端对HTML服务器控件的编程。添加属性“runat="server"”将转换XHTML元素到HTML服务器控件。
<inputid="Button2"type="button"value="button"/> <inputid="Button2"type="button"value="button"runat="server"/>工具箱内,HTML控件中的Table控件和div控件用于布局114.2.2Web服务器控件简介实现Web系统的外观、功能、操作方式等。可以从工具箱中拖到设计窗口和源码窗口,控件名字的前面具有asp:标记。根据功能不同分成标准控件、数据控件、验证控件、导航控件、登录控件、WebParts控件、AJAXExtensions控件和用户自定义控件。124.3标准控件属性名说明属性名说明AccessKey控件的键盘快捷键Font控件的字体属性Width控件的宽度Height控件的高度BackColor控件的背景色ID控件的编程标识符BoderWidth控件的边框宽度TabIndex控件的索引顺序BoderStyle控件的边框样式Text控件上显示的文本CssClass控件的CSS类名ToolTip当鼠标悬停在控件上时显示的文本CssStyle控件的样式Visible控件是否在Web页上显示Enabled是否启用Web服务器控件公共属性134.3.1Label控件用于在浏览器上显示文本,可以在服务器端动态地修改显示内容。通过Text属性指定控件显示的内容。定义的语法格式如下: <asp:LabelID=“Label1”runat=“server”Text=“Label显示的内容"></asp:Label>144.3.2TextBox控件用于输入或显示数据。语法格式如下:<asp:TextBoxID="TextBox1"runat="server"></asp:TextBox>
TextMode属性
Text属性值“SingleLine”表示单行文本框;值“Password”表示密码框,将显示特殊字符,如“*”;值“MultiLine”表示多行文本框。通过Text属性置值和取值。AutoPostBack属性值“true”表示当文本框内容改变且把焦点移出文本框时触发TextChanged事件,引起页面往返处理。AutoCompleteType属性标注能自动完成的类型,如Email表示能自动完成邮件地址列表。Focus()方法设置文本框焦点。TextChanged事件当改变文本框中内容且焦点离开文本框后触发。15实例4-3控件TextBox综合应用当页面载入时,焦点自动定位在用户名右边的文本框中;当输入用户名并把焦点移出文本框时,将触发TextChanged事件,判断用户名是否可用,若可用则在lblValidate中显示“√”,否则显示“用户名已占用!”;密码右边的文本框显示为密码框;E-mail右边的文本框具有自动完成功能。源程序:TextBox.aspx
(P77)16程序说明当页面载入时,触发Page_Load事件,将焦点定位在用户名右边的文本框中。本示例中用户合法性判断是与固定用户名“jxssg”比较,实际使用需连接数据库,与数据库中保存的用户名比较。要看到自动完成Email列表的效果,需先输入E-mail并单击确认后再次输入信息时才能看到效果。17TextBox.aspx<bodystyle="font-size:x-large"><formid="form1"runat="server"><div>
用户名:<asp:TextBoxID="txtName"runat="server"
AutoPostBack="True"OnTextChanged="txtName_TextChanged"></asp:TextBox><asp:LabelID="lblValidate"runat="server"></asp:Label><br/>
密
码:<asp:TextBoxID="txtPassword"runat="server"TextMode="Password"></asp:TextBox><br/>E-mail:<asp:TextBoxID="txtMail"runat="server"AutoCompleteType="Email"></asp:TextBox><br/><asp:ButtonID="btnSubmit"runat="server"Text="确认"/></div></form></body>18TextBox.aspx.csusingSystem;publicpartialclasschap4_TextBox:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){txtName.Focus();}protectedvoidtxtName_TextChanged(objectsender,EventArgse){if(txtName.Text=="jxssg"){lblValidate.Text="用户名已占用!";}else{lblValidate.Text="√";}}}194.3.3Button、LinkButton和ImageButton控件Button:传统按钮外观LinkButton:超链接外观ImageButton:图形外观,其图像由ImageUrl属性设置。 <asp:ButtonID="Button1"runat="server"Text="Button"/> <asp:LinkButtonID="LinkButton1"runat="server"
PostBackUrl="">
LinkButton</asp:LinkButton> <asp:ImageButtonID="ImageButton1"runat="server"ImageUrl="~/pic/map.JPG"/>20按钮控件实用属性和事件PostBackUrl属性:单击按钮时链接到的URL。Click事件:当单击按钮时被触发,执行服务器端代码。ClientClick事件:当单击按钮时被触发,执行客户端代码。21比较<a>与LinkButton
两者都能呈现超链接形式设置具体的跳转方法不同。在<a>元素中通过属性href设置,如:
<ahref=“”>链接到21世纪</a>
而在LinkButton中需要设置PostBackUrl属性或在Click事件处理代码中,通过Response对象的重定向方法Redirect()实现,如:
Response.Redirect("");22实例4-4利用Button控件执行客户端脚本要在单击Button控件后执行客户端脚本,需要使用ClientClick事件和JavaScript。源程序:ClientClick.aspx(P80)程序说明:当单击删除按钮时,触发ClientClick事件,执行JavaScript代码“returnconfirm('确定要删除记录吗?')”,弹出确认对话框。若单击“确定”按钮,触发Click事件,执行删除操作(这里仅输出信息,实际操作需连接数据库);若单击“取消”,将不再触发Click事件,运行结束。
23<body><formid="form1"runat="server"><div><asp:ButtonID="Button1"runat="server"Text="删除"OnClientClick="returnconfirm('确定要删除记录吗?')"
OnClick="Button1_Click"/></div></form></body>usingSystem;//ClientClick.aspx.cspublicpartialclasschap4_ClientClick:System.Web.UI.Page{protectedvoidButton1_Click(objectsender,EventArgse){Response.Write("删除成功!");}}实验使用三个按钮ClientClick.aspx向服务器发出事件处理请求244.3.4DropDownList控件允许用户从预定义的下拉列表中选择一项。 <asp:DropDownListID="DropDownList1"runat="server"></asp:DropDownList>25DropDownList控件实用属性和事件表DataSource属性使用的数据源。DataTextField属性对应数据源中的一个字段,该字段所有内容将被显示于下拉列表中。DataValueField属性数据源中的一个字段,指定下拉列表中每个可选项的值。Items属性列表中所有选项的集合,经常使用Items.Add()方法添加项,Clear()方法删除所有项。SelectedItem属性当前选定项。SelectedValue属性当前选定项的属性Value值
。SelectedIndexChanged事件当选择下拉列表中一项后被触发。DataBind()方法绑定数据源。26添加项到DropDownList中在属性窗口中直接对属性Items进行设置利用DropDownList对象的Items.Add()方法添加项,如: DropDownList1.Items.Add(newListItem("浙江","zhejiang"));通过属性DataSource设置数据源,再通过DataBind()方法显示数据。27实例4-5实现联动的下拉列表联动的下拉列表在实际工程项目中非常普遍,如要查询某班级的课表,需要“学年—学期—学院—班级”这样联动的下拉列表。本实例以日期联动为例,在默认情况下,显示系统日期,当改变年或月时,相应的每月天数会随之而变。28实例4-5实现联动的下拉列表(续)源程序:DropDownList.aspx
(P83)程序说明:浏览时首先触发Page_Load事件,绑定年、月、日到三个DropDownList控件。当改变年或月份时,触发相应控件的SelectedIndexChanged事件形成页面往返,将相应月份的天数绑定到ddlDay。29<bodystyle="font-size:x-large"><formid="form1"runat="server"><div><asp:DropDownListID="ddlYear"runat="server"Style="font-size:large"AutoPostBack="True"
OnSelectedIndexChanged="ddlYear_SelectedIndexChanged"Width="77px"></asp:DropDownList>年<asp:DropDownListID="ddlMonth"runat="server"Style="font-size:large"Width="47px"AutoPostBack="True"OnSelectedIndexChanged="ddlMonth_SelectedIndexChanged"></asp:DropDownList>月<asp:DropDownListID="ddlDay"runat="server"Style="font-size:large"Width="50px"></asp:DropDownList>日</div></form></body>
DropDownList.aspx.csp8330usingSystem;usingSystem.Web.UI.WebControls;publicpartialclasschap4_DropDownList:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){
if(!IsPostBack)
//页面第一次载入,向各下拉列表填充值{BindYear();BindMonth();BindDay();}
}
DropDownList.aspx.cs31protectedvoidBindYear(){ddlYear.Items.Clear();
//清空年份下拉列表中项intstartYear=DateTime.Now.Year-10;intcurrentYear=DateTime.Now.Year;//向年份下拉列表添加项for(inti=startYear;i<=currentYear;i++){ddlYear.Items.Add(newListItem(i.ToString()));}//设置年份下拉列表默认项ddlYear.SelectedValue=currentYear.ToString();
}protectedvoidBindMonth(){ddlMonth.Items.Clear();//向月份下拉列表添加项for(inti=1;i<=12;i++){ddlMonth.Items.Add(i.ToString());}
}32protectedvoidBindDay(){ddlDay.Items.Clear();//获取年、月份下拉列表选中值stringyear=ddlYear.SelectedValue;stringmonth=ddlMonth.SelectedValue;//获取相应年、月对应的天数intdays=DateTime.DaysInMonth(int.Parse(year),
int.Parse(month));//向日期下拉列表添加项for(inti=1;i<=days;i++){ddlDay.Items.Add(i.ToString());}
}protectedvoidddlYear_SelectedIndexChanged(objectsender,EventArgse){BindDay();}protectedvoidddlMonth_SelectedIndexChanged(objectsender,EventArgse){BindDay();}}//类结束实验可视化设置与属性设置334.3.5ListBox控件DropDownList和ListBox控件都允许用户从列表中选择项,区别在于DropDownList的列表在用户选择前处于隐藏状态,而ListBox的选项列表是可见的,并且可同时选择多项。<asp:ListBoxID="ListBox1"runat="server"></asp:ListBox>SelectionMode属性:值为Multiple表示允许选择多项。34实例4-6实现数据项在ListBox控件之间的移动当选择左边列表框中的项,再单击按钮后相应的项将移动到右边的列表框。源程序:ListBox.aspx
(P85)35
<asp:ListBoxID="lstLeft"runat="server"Rows="5"SelectionMode="Multiple"Style="font-size:large"Height="140px"Width="60px"><asp:ListItemValue="hunan">湖南</asp:ListItem><asp:ListItemValue="jiangxi">江西</asp:ListItem><asp:ListItemValue="beijing">北京</asp:ListItem><asp:ListItemValue="shanghai">上海</asp:ListItem><asp:ListItemValue="nanjing">南京</asp:ListItem></asp:ListBox><asp:ButtonID="btnMove"runat="server"OnClick="btnMove_Click"Style="font-size:large;position:relative;top:-55px;left:4px"Text=">"/><asp:ListBoxID="lstRight"runat="server"Rows="5"SelectionMode="Multiple"Height="140px"Width="60px"Style="position:relative;top:3px;left:12px;font-size:large;margin-right:0px"></asp:ListBox>36
usingSystem;publicpartialclasschap4_ListBox:System.Web.UI.Page{protectedvoidbtnMove_Click(objectsender,EventArgse){//遍历左边列表框中所有项
for(inti=0;i<lstLeft.Items.Count;i++)//Count发生变化{if(lstLeft.Items[i].Selected)
//判断项是否选中{//向右边列表框添加选中的一项
lstRight.Items.Add(lstLeft.Items[i]);lstLeft.Items.Remove(lstLeft.Items[i]);//调整左边列表框中剩余项索引号
i--;}}}}374.3.6CheckBox和CheckBoxList控件多项选择列表为用户提供“真/假”、“是/否”或“开/关”多项选择的方法。可以使用多个CheckBox或单个CheckBoxList,但一般采用CheckBoxList。<asp:CheckBoxID="CheckBox1"runat="server"/> <asp:CheckBoxListID="CheckBoxList1"runat="server"></asp:CheckBoxList>
384.3.6CheckBox和CheckBoxList控件(续)注意:判断CheckBox是否选中的属性是Checked,而CheckBoxList作为集合控件,判断列表项是否选中的属性是该项的Selected属性。在实际工程项目中,一般设置CheckBoxList的属性AutoPostBack值为false。要提交数据到服务器,不采用CheckBoxList的自身事件,而是常配合Button控件实现。39实例4-7CheckBoxList应用当选择个人爱好并单击提交按钮后显示选中项的提示信息。源程序:CheckBoxList.aspx(P87)<body><formid="form1"runat="server"><div><asp:CheckBoxListID="chklsSport"runat="server"Style="font-size:large"><asp:ListItemValue="football">足球</asp:ListItem><asp:ListItemValue="basketball">篮球</asp:ListItem><asp:ListItemValue="badminton">羽毛球</asp:ListItem><asp:ListItemValue="pingpong">乒乓球</asp:ListItem></asp:CheckBoxList></div><asp:ButtonID="btnSubmit"runat="server"OnClick="btnSubmit_Click"Style="font-size:large"Text="确认"/><asp:LabelID="lblMsg"runat="server"Style="font-size:large"></asp:Label></form></body>40usingSystem;usingSystem.Web.UI.WebControls;publicpartialclasschap4_CheckBoxList:System.Web.UI.Page{protectedvoidbtnSubmit_Click(objectsender,EventArgse){lblMsg.Text="您选择了:";//遍历复选框中所有项
foreach(ListItemlistIteminchklsSport.Items){if(listItem.Selected){lblMsg.Text=lblMsg.Text+listItem.Text+" ";}}}}414.3.7RadioButton和RadioButtonList控件单项选择列表用于在多种选择中只能选择一项的场合。单个的RadioButton只能提供单项选择,可以将多个RadioButton形成一组,方法是设置每个RadioButton的属性GroupName为同一名称。<asp:RadioButtonID="RadioButton1"runat="server"GroupName="group"/> <asp:RadioButtonID="RadioButton2"runat="server"GroupName="group"/>42<asp:RadioButtonListID="RadioButtonList1"runat="server"><asp:ListItem>男</asp:ListItem><asp:ListItem>女</asp:ListItem></asp:RadioButtonList>注意:判断RadioButton是否选中使用Checked属性,而获取RadioButtonList的选中项使用属性SelectedItem。参照上述例题,设计应用RadioButtonList控件的程序。434.3.8Image和ImageMap控件Image控件用于在Web窗体上显示图像,图像源文件可以使用ImageUrl属性在界面设计时确定,也可以在编程时指定。在工程实际项目中常与数据源绑定,根据数据源指定显示图像。<asp:ImageID="Image1"runat="server"ImageUrl="pic/map.JPG"/>注意:Image控件不包含Click事件,如果需要Click事件处理流程,可使用ImageButton控件代替Image控件。444.3.8Image和ImageMap控件(续)ImageMap控件除可以用来显示图像外,还可以实现图像的超链接。可以将显示的图像划分为不同形状的热点区域,分别链接到不同的网页。在工程实际项目中,常用于导航条、地图等。热点区域通过属性HotSpot设置,划分的区域有圆形CircleHotSpot、长方形RectangleHotSpot和任意多边形PolygonHotSpot,每个区域通过属性NavigateUrl确定要链接到的URL。45实例4-8利用ImageMap设计导航条整个导航条是一张图片,当设置好热点区域后,点击不同区域将链接到不同网页。源程序:ImageMap.aspx(P90)464.3.9HyperLink控件用于在网页上创建链接<asp:HyperLinkID="HyperLink1"runat="server"Target="_blank">HyperLink</asp:HyperLink>属性NavigateUrl确定要链接到的URL。属性Target:值为框架名、_blank或_self。框架名决定了在指定的框架中显示链接页,_blank决定了在一个新窗口中显示链接页,而_self决定了在原窗口中显示链接页。47ImageUrl属性设置在图片上建立链接,Text属性设置在文本上建立链接。ImageUrl优先,若找不到图片则显示属性Text设置的内容。在HyperLink中直接设置ImageUrl后显示的图形尺寸是不可调的,若要改变图形尺寸,可配合使用Image控件。注意:HyperLink控件不包含Click事件,要使用Click事件可用LinkButton控件代替。48实例4-9组合使用HyperLink和Image控件本实例页面中显示图片的尺寸与实际图片的尺寸不相同。源程序:HyperLink.aspx(P91)<body><formid="form1"runat="server"><div><asp:HyperLinkID="HyperLink1"runat="server"
NavigateUrl=""><asp:ImageID="Image1"runat="server"
ImageUrl="pic/eg_mouse.jpg"Width="50"/>
</asp:HyperLink></div></form></body>494.3.10Table控件用于在Web窗体上动态地创建表格,是一种容器控件。Table对象由行(TableRow)对象组成,TableRow对象由单元格(TableCell)对象组成。<asp:TableID="Table1"runat="server"GridLines="Both"><asp:TableRow
runat="server"><asp:TableCell
runat="server">学号</asp:TableCell><asp:TableCell
runat="server">姓名</asp:TableCell><asp:TableCell
runat="server">成绩</asp:TableCell></asp:TableRow></asp:Table>50注意:在“设计视图”中,进入Table属性窗口,使用属性Rows添加行;使用Rows的属性Cells添加单元格。在代码中添加行是建立TableRow对象;添加单元格使用TableCell对象;添加控件使用Controls对象。实例4-10动态生成表格本实例页面上的简易成绩录入界面实质是动态生成的表格。源程序:Table.aspx
(P93)51Table.aspx<asp:TableID="tblScore"runat="server"GridLines="Both"><asp:TableRowrunat="server"><asp:TableCellrunat="server">学号</asp:TableCell><asp:TableCellrunat="server">姓名</asp:TableCell><asp:TableCellrunat="server">成绩</asp:TableCell></asp:TableRow></asp:Table>5253Table.aspx.csusingSystem;usingSystem.Web.UI.WebControls;publicpartialclasschap4_Table:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){//设置初使值,实际工程中来源于数据库
string[]number={"20030201","20030202"};string[]name={"张三","李四"};
for(inti=1;i<=2;i++)
//动态生成表格{//建立一个行对象
TableRowrow=newTableRow();//建立第一个单元格对象
TableCellcellNumber=newTableCell();//建立第二个单元格对象
TableCellcellName=newTableCell();54
TableCellcellInput=newTableCell();//第三个单元格对象//设置第一个单元格的属性TextcellNumber.Text=number[i-1];cellName.Text=name[i-1];//建立一个文本框对象
TextBoxtxtInput=newTextBox();//将文本框对象添加到第三个单元格中
cellInput.Controls.Add(txtInput);//添加各单元格对象到行对象
row.Cells.Add(cellNumber);row.Cells.Add(cellName);row.Cells.Add(cellInput);//添加行对象到表格对象
tblScore.Rows.Add(row);
}}
}554.3.11Panel控件
Web窗体上的容器控件,在同一个页面上显示不同的面板内容。常用于分步显示和输入信息。每一个面板是独立的。 <asp:PanelID="Panel1"runat="server"></asp:Panel>
56实例4-11利用Panel实现简易注册页面源程序:Panel.aspx
(P95)程序说明:本程序用了三个Panel当页面载入时,首先执行Page_Load事件代码,将pnlStep1设置为可见,而将其它两个Panel控件设置为不可见。判断用户名是否重复在实际工程项目中将与数据库连接。信息也将保存到数据库中。57Panel.aspx
<bodystyle="font-size:x-large"><formid="form1"runat="server"><div><asp:PanelID="pnlStep1"runat="server"Width="902px">第一步:输入用户名<br/>用户名:<asp:TextBoxID="txtUser"runat="server">
</asp:TextBox><br/><asp:ButtonID="btnStep1"runat="server"
OnClick="btnStep1_Click“
Text="下一步"/></asp:Panel></div>
58<asp:PanelID="pnlStep2"runat="server">第二步:输入用户信息<br/>姓名:<asp:TextBoxID="txtName"runat="server"></asp:TextBox><br/>电话:<asp:TextBoxID="txtTelephone"runat="server"></asp:TextBox><br/><asp:ButtonID="btnStep2"runat="server"OnClick="btnStep2_Click"
Text="下一步"/></asp:Panel><asp:PanelID="pnlStep3"runat="server">第三步:请确认您的输入信息<br/><asp:LabelID="lblMsg"runat="server"></asp:Label><br/><asp:ButtonID="btnStep3"runat="server"Text="确定"
OnClick="btnStep3_Click"/></asp:Panel></form></body>
59publicpartialclasschap4_Panel:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){if(!IsPostBack){pnlStep1.Visible=true;pnlStep2.Visible=false;pnlStep3.Visible=false;}}protectedvoidbtnStep1_Click(objectsender,EventArgse){pnlStep1.Visible=false;pnlStep2.Visible=true;pnlStep3.Visible=false;
}protectedvoidbtnStep2_Click(objectsender,EventArgse){pnlStep1.Visible=false;pnlStep2.Visible=false;pnlStep3.Visible=true;//输出用户信息lblMsg.Text="用户名:"+txtUser.Text+"<br/>姓名:"+
txtName.Text+"<br/>电话:"+txtTelephone.Text;}protectedvoidbtnStep3_Click(objectsender,EventArgse){//TODO:将用户信息保存到数据库}}604.3.12MultiView和View控件提供了一种多视图切换显示信息的方式,可以容易地实现分页多步骤功能。在使用时,MultiView作为View的容器控件,View作为其它控件的容器控件。<asp:MultiViewID="MultiView1"runat="server"><asp:ViewID="View1"runat="server"></asp:View><asp:ViewID="View2"runat="server"></asp:View></asp:MultiView>ActiveViewIndex属性:决定了当前显示哪个视图,默认值为-1,值0表示MultiView中包含的第一个View。6162View中Button控件类型属性表CommandNameCommandArgument说明NextView不需要设置显示下一个ViewPrevView不需要设置显示上一个ViewSwitchViewByID要切换到的View控件ID切换到指定ID的ViewViewByIndex要切换到的View控件索引号切换到指定索引号的View63实例4-13利用MultiView和View实现用户编程习惯调查源程序:MultiView.aspx
(P101)64源程序:MultiView.aspx
<asp:MultiViewID="mvSurvey"runat="server">
<asp:ViewID="View1"runat="server">
<spanclass="style1">1、您从事的是哪种应用程序的编程?</span>
<asp:RadioButtonListID="rdoltView1"runat="server">
<asp:ListItemValue="webapp">Web应用程序</asp:ListItem>
<asp:ListItemValue="winapp">Windows应用程序</asp:ListItem>
</asp:RadioButtonList>
<spanclass="style1">
<asp:ButtonID="btnView1Next"runat="server"
CommandName="NextView"Text="下一个"/>
</span>
</asp:View>在行内定义一个区域65
<asp:ViewID="View2"runat="server">
2、您最常用的语言是哪一种?<br/>
<asp:RadioButtonListID="rdoltView2"runat="server">
<asp:ListItemValue="cshap">C#语言</asp:ListItem>
<asp:ListItem>Java</asp:ListItem>
</asp:RadioButtonList>
<asp:ButtonID="btnView2Prew"runat="server"
CommandName="PrevView"Text="上一个"/>
<asp:ButtonID="btnView2Next"runat="server"
CommandName="NextView"Text="下一个"
OnClick="btnView2Next_Click"/>
</asp:View>
<asp:ViewID="View3"runat="server">
谢谢您的参与!<br/>
<asp:LabelID="lblDisplay"runat="server"></asp:Label><br/>
<asp:ButtonID="btnSave"runat="server"Text="保存"
OnClick="btnSave_Click"/>
</asp:View>
</asp:MultiView>66publicpartialclasschap4_MultiView:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){if(!IsPostBack){
mvSurvey.ActiveViewIndex=0;
//设置第一个活动视图}}protectedvoidbtnView2Next_Click(objectsender,Eve
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025商品房委托购房合同
- 环保行业员工聘用规定及协议
- 停车场地地面施工合同
- 糖果制作师岗位合同
- 建筑隔音劳务分包协议模板
- 网络安全设施施工协议
- 乳胶漆粉刷施工合同注意事项
- 科学实验PVC地板施工协议
- 海鲜酒楼厨师长招聘协议
- 机场新风系统施工合同
- 2024年达州市中考数学真题试卷
- (高清版)JTGT 3365-01-2020 公路斜拉桥设计规范
- 业务连续性工作计划
- 微机原理与接口技术智慧树知到期末考试答案章节答案2024年西安工商学院
- “口腔种植修复临床护理”的专家共识
- 火电项目管理手册
- 2023年浙江省统招专升本考试英语真题及答案解析
- 食堂油锅起火演练方案及流程
- 急性胰腺炎治疗指南2024
- 千分尺内校操作指导书
- 2024年上海市奉贤区九年级中考语文一模试题卷
评论
0/150
提交评论