首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >AttributeCollection类与Attributes.Add方法的使用[通俗易懂]

AttributeCollection类与Attributes.Add方法的使用[通俗易懂]

作者头像
全栈程序员站长
发布2022-11-09 15:53:45
发布2022-11-09 15:53:45
2K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

控件属性集合:AttributeCollection类

AttitudeCollection隶属于namespace System.Web.UI命名空间。AttributeCollection类属于集合类,具有其他集合所共有的一些属性。AttributeCollection类用来封装服务器控件的所有属性,可实现对服务器属性集合的添加和删除。控件的属性包括颜色、样式、名称等,这些属性都可以通过AttributeCollection类访问到。

AttributeCollectin类的主要目的是使开发人员可以通过编程的方式访问服务器的所有属性,并实现对这些属性的编辑。

语法定义:

public sealed class AttributeCollection

AttitudeCollection类的构造函数:

public AttributeCollection(StateBag bag)

参数“bag”封装着控件的所有属性键和值

AttributeCollection类的使用方法如下:

AttributeCollection myac = TextBox1.Attributes;

TextBox1之所有拥有Attibutes属性,是因为TextBox1继承于命名空间 System.Web.UI.WebControls的WebControl类,而Attributes是WebControl类的一个属性:

public System.Web.UI.AttributeCollection Attributes { get; }

属性详解:

Count:属性集合中的属性数量

CssStyle:服务器控件的样式

Item:获取控件指定的属性

Keys:获取控件属性的键集合

典型应用:动态添加属性并遍历属性集

AttributeCollection类主要的功能是提供对控件属性的操作。本例演示如何在运行时动态添加属性,同时通过Keys属性中的方法,遍历控件的属性并打印。

代码语言:javascript
代码运行次数:0
运行
复制
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>无标题页</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
         <asp:TextBox ID="TextBox1" runat="server" ></asp:TextBox>
        <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" /></div>
    </form>
</body>
</html>
代码语言:javascript
代码运行次数:0
运行
复制
   protected void Button1_Click(object sender, EventArgs e)
    {
        AttributeCollection myac = TextBox1.Attributes; //创建当前状态集合
        Response.Write(myac.Count);//显示当前集合中的项数
        myac.Add("Name", "cgj");//添加属性到集合中
        myac.Add("OnClick", "javascript:alert('Hello');");
        IEnumerator myenum = myac.Keys.GetEnumerator();
        while (myenum.MoveNext())//遍历属性
        {
            Response.Write(myenum.Current.ToString());
        }
        myac.Remove("name");//移除集合中的属性键
    }

理解了AttitudeCollection集合类,我们对Attributes.Add方法的使用就会有更加深刻的理解,下面我们演示Attributes.Add用途与用法。

Attributes.Add(“javascript事件”,”javascript语句”);

如:

this.TextBox1.Attributes.Add(“onblue”, “window.Label1.style.backgroundColor=’#000000′;”);

this.TextBox1.Attributes.Add(“onblur”,”this.style.display=’none'”);

javascript事件:

onClick 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击

onDblClick 鼠标双击事件

onMouseDown 鼠标上的按钮被按下了

onMouseUp 鼠标按下后,松开时激发的事件

onMouseOver 当鼠标移动到某对象范围的上方时触发的事件

onMouseMove 鼠标移动时触发的事件

onMouseOut 当鼠标离开某对象范围时触发的事件

onKeyPress 当键盘上的某个键被按下并且释放时触发的事件.[注意:页面内必须有被聚焦的对象]

onKeyDown 当键盘上某个按键被按下时触发的事件[注意:页面内必须有被聚焦的对象]

onKeyUp 当键盘上某个按键被按放开时触发的事件[注意:页面内必须有被聚焦的对象]

this.txtSugStartDate.Attributes.Add(“onclick”, “return showCalendar(‘” + this.txtSugStartDate.ClientID + “‘,’y/mm/dd’) “); this.txtSugStartDate.Attributes.Add(“readonly”, “true”); this.txtSugEndDate.Attributes.Add(“onclick”, “return showCalendar(‘” + this.txtSugEndDate.ClientID + “‘,’y/mm/dd’)”); this.txtSugEndDate.Attributes.Add(“readonly”, “true”); this.txtProcessStartDate.Attributes[“onclick”] = “return showCalendar(‘” + this.txtProcessStartDate.ClientID + “‘,’y/mm/dd’)”; this.txtProcessStartDate.Attributes[“readonly”] = “true”; this.txtProcessEndDate.Attributes[“onclick”] = “return showCalendar(‘” + this.txtProcessEndDate.ClientID + “‘,’y/mm/dd’)”; this.txtProcessEndDate.Attributes[“readonly”] = “true”;

使用举例:

//首先要在PageLoad()事件中注册属性 protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { Button1.Attributes.Add(“onclick”, “return checkSame()”);//为Button1添加onclick()事件 ,Button为服务器控件 }//注意:checkSame()这是一个写在aspx面页的js函数,必须有返回值,为:true 或 false }

//接着写Button1的onclick事件,如果刚才的checkSame()返回为true则招行下面的事件,否则不执行

protected void Button1_Click(object sender, ImageClickEventArgs e) { SqlParameter[] Params = new SqlParameter[2]; Params[0] = dbs.MakeInParams(“@uid”, SqlDbType.VarChar, 10, Session[“Uid”].ToString()); Params[1] = dbs.MakeOutParms(“@Upwd”, SqlDbType.VarChar, 10); if (dbs.ExecuteNonQuery(CommandType.StoredProcedure, “selectPwd”, Params) > 0) { string userPwd = Params[1].Value.ToString(); if (userPwd != this.old_pwd.Text) { Response.Write(“<script>alert(‘原始密码错误!’)</script>”); } else { } } else { ClientScript.RegisterStartupScript(this.GetType(), “”, “<script>alert(‘操作失败!’)</script>”); }

}

//呵呵。。再写一个js试例吧 function checkSame() { var Obj1=document.getElementById (“new_pwd”).value; var Obj2=document.getElementById (“re_new_pwd”).value; if(Obj1!=Obj2) { alert(“两次密码输入不一致!”); document.getElementById(“new_pwd”).focus(); return false; } else { return true; } }

//明白了吗。。这是一个用来判断两次密码输入是否一致的函数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月26日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档