首页技术autoeventwireup?asp.net的控件

autoeventwireup?asp.net的控件

编程之家2023-11-01145次浏览

大家好,感谢邀请,今天来为大家分享一下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.

autoeventwireup?asp.net的控件

Static–指定ID的值,在渲染控件时不会发生变化.

Predictable–指定后缀,然后和容器控件的ID属性进行合并.

Inherit–继承父控件的设置.

注意,Page的默认ClientIDMode属性的值是AutoID,可以通过@ Page指令设置页面级的值,还可以通过修改Web配置文件设置应用程序级的值.

[pre]

<system.web>

autoeventwireup?asp.net的控件

<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,本文到此结束,如果可以帮助到大家,还望关注本站哦!

wordpress seo?wordpress怎么优化seo服务器干什么用的,服务器的作用是什么