标签:
一,用户控件与页面的区别
1.扩展名:用户控件——.ascx 页面——.aspx
2.内容:页面有完整的HTML标记,用户控件没有
3.声明指示符:页面<%@ Page ...%> 用户控件<%@ Control ...%>
4.类的派生:页面派生自Page,用户控件派生自UserControl
5.页面可以独立运行,用户控件不能,它只能放在页面中才能运行
二,用户控件的好处
1.最大限度的实现代码重用,省去重复写代码的麻烦
2.团队合作时可以实现分工开发,节省时间
3.结构良好
三,用户控件使用过程中的几个难点
1.交换信息
(1)从外向内操作——在页面中操作用户控件里面的控件
I,事先给用户控件定义属性,通过属性给用户控件赋值
案例:在页面中点击按钮将文本框中的值送到用户控件里的Lable中去
先在用户控件中定义一个LableValue的属性
public string LabelValue { get { return Label1.Text; } set { Label1.Text = value; } }
在页面中编写按钮点击的代码
protected void Button1_Click(object sender, EventArgs e) { //把文本框的值取出来 string s = TextBox1.Text; //送到用户控件的label中去 WUC1.LabelValue = s; }
II,使用用户控件对象的FindControl()方法找到它里面的控件,强制转换出来对它进行操作
protected void Button2_Click(object sender, EventArgs e) { //把文本框的值取出来 string s = TextBox1.Text; //送到用户控件的label中去 Label lbl = (Label)WUC1.FindControl("Label1"); lbl.Text = s; }
(2)从内向外操作——在用户控件中操作它所在页面的控件
2.路径(必须在同一级别目录下)
(1)标签/控件(不是从工具箱里拖出来的控件,是自己手写的HTML标签)的路径——只需在其标签内加上runat=server标记即可(注:此时必须再加上id=“xxx”)
(2)样式表的路径——使用外部样式表(样式表的目录和图片目录是固定的,无论页面和用户控件在哪个目录下都不影响样式表中的路径)
(3)外部脚本文件的路径——使用ResolveClientUrl()来动态转换路径
(4)C#代码路径问题——Response. Redirect("~/路径"):按目录从上到下的顺序找
<script src="<%=ResolveClientUrl("Script/JavaScript.js")%>"></script> //括号内为JS脚本代码路径
3.命名——任何带有runat=server的标签/控件,放到用户控件中后,在生成的HTML中,它的ID和Name都会发生一些变化。
Web标准控件的ID,ClientID,UniqueID区别?
ID - 设计时候的控件的ID。控件的这个对象的变量名。
ClientID - 运行呈现为HTML后的ID名。
UniqueID - 运行呈现为HTML后的Name名。
如何在JS中获得它们生成出来的HTML中的ID
var t = document.getElementById("<%= TextBox1.ClientID %>");
案例1:新闻分类显示
1.造用户控件,将每种类型的新闻都造成一个用户控件(此处只造一个用户控件即可,在其中利用添加属性的方法。给其设置不同的新闻类型来控制其显示不同的内容)
public partial class NewsUC : System.Web.UI.UserControl { private string _NewsType; public string NewsType { set { _NewsType = value; } } private string _BgColor; public string Bgcolor { get { return _BgColor; } set { _BgColor = value; } } private NewsDBDataContext context = new NewsDBDataContext(); protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { var q1 = context.News.Where(p=>p.type==_NewsType); Repeater1.DataSource = q1; Repeater1.DataBind(); } } }
2.在用户控件中设计界面,使用Repeater
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="NewsUC.ascx.cs" Inherits="NewsUC" %> <div style="background-color:<%=Bgcolor%>;"> <asp:Repeater ID="Repeater1" runat="server"> <ItemTemplate> <div style="margin-bottom:10px;font-size:12px;"> <span><%#Eval("title") %></span>(<span><%#Eval("time","{0:yyyy.MM.dd}") %></span>) </div> </ItemTemplate> </asp:Repeater> </div>
3.造主页面,显示不同类型的新闻,并给其加上事先设置好的属性
<body> <form id="form1" runat="server"> 国内新闻:<br /> <br /> <uc1:NewsUC ID="NewsUC1" runat="server" NewsType="0" Bgcolor="#FFFFaa" /> <p> 国际新闻</p> <uc1:NewsUC ID="NewsUC2" runat="server" NewsType="1" Bgcolor="#aaFFFF" /> <p> 娱乐新闻</p> <uc1:NewsUC ID="NewsUC3" runat="server" NewsType="2" Bgcolor="#FFaaFF" /> <p> 财经新闻</p> <uc1:NewsUC ID="NewsUC4" runat="server" NewsType="3" Bgcolor="#aaFFaa" /> </form> </body>
标签:
原文地址:http://www.cnblogs.com/William-1234/p/4561390.html