在新建项的时候,选择Web用户控件,可用来自定义自己的控件,做好后,直接拖到页面即可使用
自定义控件与WEB交互,需要在 自定义控件里面 写 属性,如:

    public string CityID
{
get { return this.DropDownList1.SelectedValue; } set{ this.DropDownList1.SelectedValue = value;}
}

在外面调用的时候如下即可:

Label1.Text = this.City1.CityID;

自定义样式(公开属性)

    public ConsoleColor Color { get; set; }
public string Title { get; set; }

定义 样式属性

<h1><%=this.Title  %></h1>
<div style='background-color:<%=this.Color%>'>
组装的一些控件
</div>

样式调用

 this.City1.Title = "标题";
this.City1.Color = ConsoleColor.Blue;
Web用户控件 公开事件

由于控件是 封装过的,所以当用户控件激发事件时,最外层是得不到数据的,解决办法有3种:

注:用户控件需设置 AutoPostBack="True"

-------- 1.利用系统的 EventHandler 委托

<1>.在用户控件后台文件内新建一个属性

    public string CityID
{
get { return DropDownList1.SelectedValue; }
set { DropDownList1.SelectedValue = value; }
}

<2>.新建一个 event 事件

public event EventHandler CitySelected = null;

<3>.当用户控件中的SelectedIndexChanged事件触发时,激活 CitySelected 事件

    protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
if (this.CitySelected != null)
{
this.CitySelected(this, null);
}
}

<4>.在页面的后台 新建一个方法,用来处理用户控件返回的信息

    public void showCity(object sender, EventArgs e)
{
this.Label1.Text = this.City1.CityID;
}

<5>.在页面的用户控件中 注册事件

<uc1:City ID="City1" runat="server" OnCitySelected="showCity" />
利用自定义的 委托

<1>.自定义一个委托

public delegate void CitySelectedEventHander(string CityID);

<2>.自定义一个事件

    public event CitySelectedEventHander CitySeleted = null;

<3>.当用户控件触发时,激活自定义事件

    protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
if (CitySeleted != null)
{
string CityID = this.DropDownList1.SelectedValue;
this.CitySeleted(CityID);
}
}

<4>.在页面后台新建一个方法,用于处理用户控件的事件

    public void ShowCity(string id)
{
this.Label1.Text = id;
}

<5>.在页面的用户控件中 注册事件

    <uc1:City2 ID="City21" runat="server" onCitySeleted="ShowCity" />
利用系统委托 泛型事件(推荐使用)

<1>.定义一个类,继承EventArgs类,主要用于封装属性,以便日后扩展

    public class CityEventArgs:EventArgs
{
public string CityID { get; set; }
}

<2>.定义一个 泛型事件,用自定义的类做 参数

    public event EventHandler<CityEventArgs> CitySeleted = null;

<3>.在页面后台新建一个方法,用于处理用户控件的事件

    public void ShowCity(object sender,CityEventArgs e)
{
this.Label2.Text = e.CityID;
}

<4>.在页面的用户控件中 注册事件

    <uc1:City3 ID="City31" runat="server" OnCitySeleted="ShowCity" />

注:注册事件也可用如下方法:

    protected void Page_Load(object sender, EventArgs e)
{
this.City31.CitySeleted += new EventHandler<CityEventArgs>(City31_CitySeleted);
} void City31_CitySeleted(object sender, CityEventArgs e)
{
this.Label2.Text = e.CityID;
}
动态增加用户控件

在上面的基础上,增加如下内容:

Control c = this.LoadControl("City3.ascx");
City3 uc = c as City3;
uc.CityID = "SH";
this.PlaceHolder1.Controls.Add(uc);

注:PlaceHolder1是容器,当前页面需要在头部注册信息

<%@ Register src="~/UC/City3.ascx" tagname="City3" tagprefix="uc1" %>

Web用户自定义控件的更多相关文章

  1. mvc 母版页、用户自定义控件

    母版页(Master) 1.母版页是与Controller无关的,母版页只是一个View文件,而没有任何Controller与之相对应. 2.其实在ASP.NET MVC中View的aspx与母版页并 ...

  2. C#用户自定义控件(含源代码)-透明文本框

    using System; using System.Collections; using System.ComponentModel; using System.Drawing; using Sys ...

  3. WEB用户访问控制方法

    分享到 一键分享 QQ空间 新浪微博 百度云收藏 人人网 腾讯微博 百度相册 开心网 腾讯朋友 百度贴吧 豆瓣网 搜狐微博 百度新首页 QQ好友 和讯微博 更多... 百度分享 一直以来,我对用户/权 ...

  4. LWP::UserAgent - Web user agent class Web 用户agent 类:

    LWPUserAgent: LWP::UserAgent - Web user agent class Web 用户agent 类: 概述: require LWP::UserAgent; my $u ...

  5. 转 Web用户的身份验证及WebApi权限验证流程的设计和实现

    前言:Web 用户的身份验证,及页面操作权限验证是B/S系统的基础功能,一个功能复杂的业务应用系统,通过角色授权来控制用户访问,本文通过Form认证,Mvc的Controller基类及Action的权 ...

  6. WPF中添加Winform用户自定义控件

    过程:创建WPF工程->创建Winform用户自定义控件工程->WPF中引用控件->添加到Xaml页面 1.首先在WPF工程的解决方案上右击选择添加新建项目: 选择Windows窗体 ...

  7. [置顶] Web用户的身份验证及WebApi权限验证流程的设计和实现 (不是Token驗證!!!不是Token驗證!!!都是基於用户身份的票据信息驗證!!!)

     转发 http://blog.csdn.net/besley/article/details/8516894 不是Token驗證!!!不是Token驗證!!!都是基於用户身份的票据信息驗證!!! [ ...

  8. Web用户的身份验证及WebApi权限验证流程的设计和实现 asp.net mvc AllowAnonymous 不起作用, asp.net mvc 匿名访问

    原文地址: https://blog.csdn.net/zjlovety/article/details/17095627 前言:Web 用户的身份验证,及页面操作权限验证是B/S系统的基础功能,一个 ...

  9. H3C 交换机设置telnet WEB用户

    huwei : local-user admin password cipher @#$@#$ service-type telnet ssh service-type telnet ssh leve ...

随机推荐

  1. 2015 CCPC D- Pick The Sticks(UESTC 1218) (01背包变形)

    http://acm.uestc.edu.cn/#/problem/show/1218 既然二维dp表示不了,就加一维表示是否在边界放置,放置一个,两个.有一个trick就是如果只放一根,那么多长都可 ...

  2. poj 1523 SPF【点双连通求去掉割点后bcc个数】

    SPF Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 7246   Accepted: 3302 Description C ...

  3. Dreamweaver中清除php代码中多余空行的方法

    使用DW自带的搜索功能,利用正则表达式 使用正则表达式搜索:\r\n\s*\r\n即可搜到代码中的空行,再用回车符\n替换即可消除代码中的多余空行

  4. List 排序

    1:sort 这种实现是用朗姆达表达式实现.Comparison<T> 委托详见 http://msdn.microsoft.com/zh-cn/library/tfakywbh.aspx ...

  5. android内存优化发展——使用软引用

    整个Android开发者一定是遇到了内存溢出这个头疼的问题,一旦这个问题.很难直接决定我们的应用程序是哪里出了问题,为了找到问题的解决方案,必须累积发行通过一些内存分析工具高速定位和强大的体验,现在详 ...

  6. direct3D directX

    direct3D只是directX其中一个增强功能 DirectX是由很多API组成的,按照性质分类,可以分为四大部分,显示部分.声音部分.输入部分和网络部分. 显示部分担任图形处理的关键,分为Dir ...

  7. vim乱码处理

    编辑~/.vimrc文件,加上如下几行: set fileencodings=utf-8set termencoding=utf-8set encoding=utf-8

  8. java与.net比较学习系列开发环境和常用调试技巧常用操作快捷键

    调试         F5 F11 调试运行   CTRL+F5 暂无 非调试运行   F6 不适用 编译整个解决方案   SHIFT+F6 不适用 编译当前选择的工程   SHIFT+F5 CTRL ...

  9. Python 基础【第二篇】python操作模式

    一.交互模式 #python Python 2.6.6 (r266:84292, Jan 22 2014, 09:42:36) [GCC 4.4.7 20120313 (Red Hat 4.4.7-4 ...

  10. 第十一篇:web之Django之Form组件

    Django之Form组件   Django之Form组件 本节内容 基本使用 form中字段和插件 自定义验证规则 动态加载数据到form中 1. 基本使用 django中的Form组件有以下几个功 ...