用户控件中使用客户端脚本的控件名称问题
2008-04-24 15:32
344 查看
[/b] asp.net提供一种很好的模块级的复用技术――用户控件,大大方便了web网站的建设,提高了效率。用户控件使用多了,碰到的问题也会增多。最近遇到一个问题,就是如果在一个用户控件中要使用到客户端脚本,而这个客户端的脚本又要访问到控件中包含的控件,问题就出现了。问题是当一个用户控件被包含到一个aspx页面后,呈现到用户客户端后,整个用户控件中的控件的名称将会有所变化,它们不再是你设计这个用户控件时的名称,而是有两个相关的名称:
id[/b] ―― 客户端可以通过这个id访问这个客户端控件,asp.net给每个控件输出的id形式为“用户控件id_此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id_下层用户控件id_此控件的id”name[/b] ―― 客户端也可以通过这个name来访问这个客户端控件,asp.net给每个控件输出的name“用户控件id:此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id:下层用户控件id:此控件的id”。 [/b]例子:<input name="WebUserControl11:TextBox1" type="text" id="WebUserControl11_TextBox1" />在设计用户控件时,放置了一个TextBox,id为TexBox1,这个用户控件被放置到一个aspx页面,用户控件的id为WebUserControl11,最后这个用户控件的TextBox到客户端后就是上面的这个样子的了。 客户端提交到服务端时是根据控件的name来提交的,也就是说,对服务端来讲,客户端的name是有意义的,id是不需要的。在写客户端脚本时你不能预知你的用户控件将会是以什么id加入到aspx页面的,也不能预知用户控件被嵌套了多少层,所以你根本不能在设计时来参考这些控件。幸好,asp.net的webcontrol 和 htmlcontrol 的控件有个运行时属性 UniqueID,用来获取服务器控件的唯一的、以分层形式限定的标识符。对应到上面的那个例子,控件TextBox1的UniqueID就是“WebUserControl11:TextBox1”,跟生成的客户端的控件的name相一致。所以我们可以用控件的UniqueID来获得运行时客户端的name,也就能通过这个name来控制客户端控件了。OK,按照这个思路来设计个客户端脚本:用户控件很简单,就放置一个TextBox,我们再给这个TextBox设置一个鼠标经过事件来触犯客户端的脚本,给TextBox赋一个值,代码如下:<%@ Control Language="c#" AutoEventWireup="false" Codebehind="WebUserControl1.ascx.cs" Inherits="WebApplication3.WebUserControl1" TargetSchema="http://schemas.microsoft.com/intellisense/ie5"%><asp:TextBox id="TextBox1" runat="server" onmouseover="over()"></asp:TextBox><script language=javascript><!--function over(){ document.all.<%= TextBox1.UniqueID%>.value = "kent";}//--></script>将这个用户控件拖放到一个aspx页面中,编译浏览这个页面,报一个脚本错误:缺少‘;’[/b][/b]把鼠标移到TextBox时,又报一个脚本错误:“缺少对象[/b]” 检查发现,客户端引用的标示不能含有”:”符号,就是说在客户端不能用控件的name来参考。asp.net的webcontrol 和 htmlcontrol 的控件还有个运行时属性 ClientID,它用来获取由 ASP.NET 生成的服务器控件标识符,也就是来获取控件的客户端id的,我们再改用这个属性来试一下: document.all.<%= TextBox1.ClientID %>.value = "kent"; 再运行,OK成功,当鼠标移动TextBox时,TextBox中出现了“kent”。
id[/b] ―― 客户端可以通过这个id访问这个客户端控件,asp.net给每个控件输出的id形式为“用户控件id_此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id_下层用户控件id_此控件的id”name[/b] ―― 客户端也可以通过这个name来访问这个客户端控件,asp.net给每个控件输出的name“用户控件id:此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id:下层用户控件id:此控件的id”。 [/b]例子:<input name="WebUserControl11:TextBox1" type="text" id="WebUserControl11_TextBox1" />在设计用户控件时,放置了一个TextBox,id为TexBox1,这个用户控件被放置到一个aspx页面,用户控件的id为WebUserControl11,最后这个用户控件的TextBox到客户端后就是上面的这个样子的了。 客户端提交到服务端时是根据控件的name来提交的,也就是说,对服务端来讲,客户端的name是有意义的,id是不需要的。在写客户端脚本时你不能预知你的用户控件将会是以什么id加入到aspx页面的,也不能预知用户控件被嵌套了多少层,所以你根本不能在设计时来参考这些控件。幸好,asp.net的webcontrol 和 htmlcontrol 的控件有个运行时属性 UniqueID,用来获取服务器控件的唯一的、以分层形式限定的标识符。对应到上面的那个例子,控件TextBox1的UniqueID就是“WebUserControl11:TextBox1”,跟生成的客户端的控件的name相一致。所以我们可以用控件的UniqueID来获得运行时客户端的name,也就能通过这个name来控制客户端控件了。OK,按照这个思路来设计个客户端脚本:用户控件很简单,就放置一个TextBox,我们再给这个TextBox设置一个鼠标经过事件来触犯客户端的脚本,给TextBox赋一个值,代码如下:<%@ Control Language="c#" AutoEventWireup="false" Codebehind="WebUserControl1.ascx.cs" Inherits="WebApplication3.WebUserControl1" TargetSchema="http://schemas.microsoft.com/intellisense/ie5"%><asp:TextBox id="TextBox1" runat="server" onmouseover="over()"></asp:TextBox><script language=javascript><!--function over(){ document.all.<%= TextBox1.UniqueID%>.value = "kent";}//--></script>将这个用户控件拖放到一个aspx页面中,编译浏览这个页面,报一个脚本错误:缺少‘;’[/b][/b]把鼠标移到TextBox时,又报一个脚本错误:“缺少对象[/b]” 检查发现,客户端引用的标示不能含有”:”符号,就是说在客户端不能用控件的name来参考。asp.net的webcontrol 和 htmlcontrol 的控件还有个运行时属性 ClientID,它用来获取由 ASP.NET 生成的服务器控件标识符,也就是来获取控件的客户端id的,我们再改用这个属性来试一下: document.all.<%= TextBox1.ClientID %>.value = "kent"; 再运行,OK成功,当鼠标移动TextBox时,TextBox中出现了“kent”。
相关文章推荐
- 用户控件中使用客户端脚本的控件名称问题 (转)
- 用户控件中使用客户端脚本的控件名称问题
- 绝对酷,如何解决asp.net中javascript脚本的问题(使用服务器控件执行客户端脚本)
- 代码碎片(用户控件使用客户端脚本)
- 绝对酷,如何解决asp.net中javascript脚本的问题(使用服务器控件执行客户端脚本)
- winform用户控件使用数据库dal层的问题
- [原创]用户控件中使用Js,如何在客户端引用用户控件中某个控件的ID
- Ajax.Net在用户控件中使用Session时的问题
- 使用脚本操作UpdatePanel中控件的问题
- 使用用户控件遇到的小问题,不断更新
- Asp.net开发心得点滴[动态加载的用户控件使用事件委托,交给页面处理的事件无效问题]
- .NET----使用母版页后,控件名称自动生成导致js无法正常操作.net控件的问题
- 使用c++builder中stringgird控件和设定行名称和列名称的问题
- 【SharePoint】SharePoint2013中使用客户端对象模型给用户控件赋初值
- 使用MVC框架中要注意的问题(五):如何在页面和用户控件之间传递数据
- 用户控件中使用相对路径问题
- 有关C#+ASP.NET中用户控件(webusercontrol)使用问题2则
- 关于使用CreateUserWinzard控件创建用户时出现连接数据库问题的解决方法
- 用户控件中使用图片的路径问题
- [置顶] MFC树形控件CTreeCtrl使用方法、遍历、SetCheck无效、根据名称获取节点、获取选中节点等问题