autoeventwireup?asp.net的控件
大家好,感谢邀请,今天来为大家分享一下autoeventwireup的问题,以及和asp.net的控件的一些困惑,大家要是还不太明白的话,也没有关系,因为接下来将为大家分享,希望可以帮助到大家,解决大家的问题,下面就开始吧!
asp.net的控件
asp net的控件分为内置和外置两种。asp net的内置控件分为两种:HTML控件(HTML control)和用户控件(User control)。外置控件,在使用前,需要将其添加到Visual Studio.NET环境中。然后就可以通过启动一个新项目来使用新的控件。虽然有的时候,控件在开发机器上运行正常,但当程序被部署到终端用户机器上时,会出现问题。因为很多终端机器不允许安装外置控件,对于上述问题有简单实用的解决办法-“在服务器上部署“fp_client”文件夹”。
fp_client文件夹包含所有ASPNET外置控件需要的脚本文件。拿Spread控件为例,Web页面上的 Spread控件实例从服务器上的 fp_client文件夹中读取前台格式化、样式和脚本功能。fp_client文件夹的默认安装路径是:C:\Program Files\GrapeCity\Spread.ASP.5.dotNet20\v5.0.2015\fp_client\fpspread\5_0_2015_2008\HTC
我们需要在 web.config文件中添加以下代码 fp_client文件夹进行正确的加载:<appSettings><addkey=fp_clientvalue=fp_client/></appSettings>下面是两个有助于我们更加深入的去解决该问题问题的相关点:1.上面的标签仅在你想要从程序根目录下载“fp_client”文件夹是需要,在这种情况下,你需要复制 fp_client文件夹并且把它粘帖到程序的根目录下,或者创建一个映射到 fp_client文件夹的虚拟路径。2.在服务器上有很多网址运行 Spread for ASPNET,我们仅需要把 fp_client文件夹复制到服务器的根目录上即可(而不是程序的根目录)。在这种情形下,上述 web.config标签是不需要添加的,程序仍然可以完美运行。 1、ClientIDMode
渲染ASP NET控件时会自动生成一个ID,当在客户端脚本中引用它们时,却会制造不少麻烦,虽然它是命名容器和ID的简单串联,但仍然无法预测生成的ID范围.
ASP NET 4.0使用ClientIDMode属性解决了这个问题,它允许控制生成这些ID的方法,ClientIDMode有四个可选择的值:AutoID,Static,Predictable和Inherit.下面是这四个值的含义解释:
AutoID–和4.0以前的版本保持一致,自动生成ID.
Static–指定ID的值,在渲染控件时不会发生变化.
Predictable–指定后缀,然后和容器控件的ID属性进行合并.
Inherit–继承父控件的设置.
注意,Page的默认ClientIDMode属性的值是AutoID,可以通过@ Page指令设置页面级的值,还可以通过修改Web配置文件设置应用程序级的值.
[pre]
<system.web>
<pages clientIDMode=Predictable></pages></system.web>
[/pre]
2、Meta关键字和Meta描述
在ASP NET 4.0中Page类增加了两个新的属性:Meta Keywords和Meta Description,可以在运行时设置这两个属性,通过数据库或其它源驱动,并允许动态设置标签,描述特定的页面,下面的Page标签显示了这两个属性. [pre]<%@PageLanguage=C#AutoEventWireup=trueKeywords=keyword1,keyword2Description=mydescription%>C#AutoEventWireup=trueKeywords=keyword1,keyword2Description=mydescription%>C#AutoEventWireup=trueKeywords=keyword1,keyword2Description=mydescription%>[/pre]3、数据绑定控件中的行持久性选择
ASP NET数据绑定控件,如Grid View,都支持行选择,但它们应该选择每个页面上相同编号的行,但ASP NET 4.0以前的版本中,行持久性选择是不能实现的,因为以前的版本选择后续页面上的行时是基于行索引的,ASP NET 4.0提供了一个直观的方法解决了这一问题.
数据绑定控件现在提供了一个EnablePersistedSection属性,它可以帮助实现行持久性选择。
4、AutoEventWireup
AutoEventWireup是很少使用但知名度很高的一个ASP NET属性,简单地说,它设置为True时,在未明确委派的情况下,允许自动调用页面事件。
它的默认值是True,AutoEventWireup属性的缺点在MSDN上有详细描述:它限制了命名事件处理程序的灵活性,另一个缺点是对性能的不利影响,对于高流量的网站,性能影响是巨大的.
5、Page的Header属性
Page类现在提供了Header属性,可以在运行时绑定它,下面的代码示例显示了如何明确设置Title属性.
this.Header.Title= My page title;
当根据某个规则动态关联一个样式表时,这个属性非常方便,在这种情况下,打印页面是理想的候选. [pre]HtmlLinkprintLink=newHtmlLink();printLink.Attributes.Add(type,text/css);printLink.Attributes.Add(rel,stylesheet);printLink.Attributes.Add(href,css/print.css);this.Header.Controls.Add(printLink);[/pre]6、AssociatedControlID属性
可以在一个Web表单中将一个控件关联到另一个服务器控件,这时需要使用服务器控件的AssociatedControlID属性,当根据某些行为为关联的控件设置热键时,这个属性就可以派上用场了.
AssociatedControlID属性的默认值是一个空字符串,它表示控件未与任何服务器控件关联,下面的代码显示了一个Textbox控件是如何与Label服务器控件关联的.
7、ControlState属性
ASP NET最重要的状态管理技术是ViewState,它允许你在往返Web服务器的路上保留值,但由于可在父级关闭,它并不是保存信息可靠的方法.
ASP NET 2.0为服务器控件引入了私有的ViewState,叫做ControlState,它可用来存储控件的关键信息,ASP NET可以处理它的序列化和反序列化.
注意,使用时必须谨慎,因为它会影响页面的性能.
8、Control.PreserveProperty
针对传统的视图状态用法,Rick Strahl为我们提供了另一个选择:PreservedProperties,它可以保存控件ID和属性名称,详细信息请参考Implementing an ASP NET PreserveProperty Control(实现ASP NET PreserveProperty控件).
9、PreviousPageType指令
PreviousPageType指令是ASP NET 2.0跨页面回送机制的一部分,允许指定来源页面的虚拟路径,以便强类型访问来源页面.正常情况下,发送的数据可通过PreviousPage属性和FindControl方法访问,但使用强类型的PreviousPageType指令允许你访问公共属性,而不需要调用FindControl方法.
C# findcontrol的用法
1.FindControl的使用方法:
Control.FindControl(String):在当前的命名容器中搜索带指定 id
参数的服务器控件。(有点类似javascript中的getElementById(string))
简单的例子:
<form
id="form1" runat="server">
<div>
<asp:TextBox
ID="TextBox1" runat="server">TextBox</asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click"
/>
<br/>
<asp:Label ID="Label1"
runat="server"
Text="Label"></asp:Label></div>
</form>
如果需要获得页面中的"TextBox1",代码中可以使用this.TextBox1来引用,这里我们使用FindControl:
protected void Button1_Click(object
sender, EventArgs e)
{
//Control c=
this.FindControl("TextBox1");
//TextBox tb=(TextBox)c;
//FindControl返回的是一个Control类型的控件,需要强制类型转化成TextBox类型
TextBox
tb=(TextBox)this.FindControl("TextBox1");
this.Label1.Text=
tb.Text;}
当TextBox1放到其他控件里应该怎么查找呢?
<div>
<asp:Panel ID="Panel1" runat="server" Height="50px";125px">
<asp:TextBox ID="TextBox1"
runat="server">TextBox</asp:TextBox>
<asp:Label
ID="Label1" runat="server" Text="Label"></asp:Label>
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click"
/>
</asp:Panel>
</div>
当TextBox1放到Panel里,似乎没什么影响 TextBox
tb=(TextBox)this.FindControl("TextBox1"),当查看生存页
面的HTML代码是发现,TextBox的ID并没有改变,所以可以获得TextBox1。
<div>
<div
id="Panel1" style="height:50px;;">
<input name="TextBox1"
type="text" value="TextBoxdsd" id="TextBox1"/>
<span
id="Label1">TextBoxdsd</span>
<input type="submit"
name="Button1" value="Button" id="Button1"/>
</div>
</div>
当TextBox1放到DataGrid中
<asp:DataGrid
ID="dg1" runat="server"
OnSelectedIndexChanged="dg1_SelectedIndexChanged">
<Columns>
<asp:TemplateColumn>
<ItemTemplate>
<asp:TextBox ID="TextBox1"
runat="server"></asp:TextBox>
</ItemTemplate>
</asp:TemplateColumn>
<asp:ButtonColumn CommandName="Select"
Text="选择"></asp:ButtonColumn>
</Columns>
</asp:DataGrid>
这时候this.FindControl("TextBox1")==null,无法获得TextBox1,查看生成页面HTML发现,页面有多个
<input
name="dg1$ctl02$TextBox1" type="text" id="dg1_ctl02_TextBox1"/>
<input
name="dg1$ctl03$TextBox1" type="text" id="dg1_ctl03_TextBox1"
/>
TextBox1隐藏了,给DataGrid添加选择列,通过以下方法获得被选择行的TextBox1
protected void
dg1_SelectedIndexChanged(object sender, EventArgs e)
{
Control
c= this.dg1.Items[this.dg1.SelectedIndex].FindControl("TextBox1");
//Control c= this.dg1.SelectedItem.FindControl("TextBox1");
TextBox
tb=(TextBox)c;
tb.Text="TextBox";
}
protected void dg1_EditCommand(object
source, DataGridCommandEventArgs e)
{
TextBox tb=
(TextBox)e.Item.FindControl("TextBox1");
this.Label1.Text=
tb.Text.ToString();
}
如果是在DataGrid的页眉和页脚:
((TextBox)this.dg1.Controls[0].Controls[0].FindControl("TextBoxH")).Text
=
"Head";
((TextBox)this.dg1.Controls[0].Controls[this.dg1.Controls[0].Controls.Count
- 1].FindControl
("TextBoxF")).Text=
"Footer";
TextBox1在Repeater中
<asp:Repeater ID="Repeater1"
runat="server" DataSourceID="SqlDataSource1"
OnItemCommand="Repeater1_ItemCommand">
<ItemTemplate>
<asp:TextBox ID="TextBox1" runat="server"
Text=""></asp:TextBox><%#DataBinder.Eval
(Container.DataItem,"ProductName")%><asp:Button ID="btn"
OnClick="btn_click" runat="server"
Text="dddd"/><br/>
</ItemTemplate>
</asp:Repeater>
通过按钮来获得TextBox1:
protected void btn_click(object
sender, EventArgs e)
{
//获得按钮
Button btn=
(Button)sender;
TextBox tb=
(TextBox)btn.Parent.FindControl("TextBox1");
tb.Text="Text";
}
或者
foreach(RepeaterItem item in
this.Repeater1.Items)
{
((TextBox)item.FindControl("TextBox1")).Text="Text2";
}
自定义控件里的TextBox1
<%@ Control
Language="C#" AutoEventWireup="true"
CodeFile="WebUserControl.ascx.cs"
Inherits="WebUserControl"
%>
<asp:TextBox ID="TextBox1"
runat="server"></asp:TextBox>
引用<uc1:WebUserControl
ID="WebUserControl1" runat="server"/>
获取TextBox1:
((TextBox)this.WebUserControl1.FindControl("TextBox1")).Text=
"userc";
模板页访问页面TextBox1
//模板页的TextBox1
TextBox
tbM=(TextBox)this.FindControl("TextBox1");
//页面中的TextBox1
TextBox tbC=
(TextBox)this.FindControl("ContentPlaceHolder1").FindControl("TextBox1");
tbC.Text= tbM.Text;
页面使用模板页的TextBox1
//模板页的TextBox1
TextBox
tbM=(TextBox)Master.FindControl("TextBox1");
//本页面的TextBox1
//错误的方法:TextBox tbC=
(TextBox)this.FindControl("TextBox1");
TextBox tbC=
(TextBox)Master.FindControl("ContentPlaceHolder1").FindControl("TextBox1");
tbM.Text= tbC.Text.ToString();
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!