用户控件中使用客户端脚本的控件名称问题

原创 2003年07月28日 08:43:00

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

asp.net提供一种很好的模块级的复用技术――用户控件,大大方便了web网站的建设,提高了效率。用户控件使用多了,碰到的问题也会增多。最近遇到一个问题,就是如果在一个用户控件中要使用到客户端脚本,而这个客户端的脚本又要访问到控件中包含的控件,问题就出现了。问题是当一个用户控件被包含到一个aspx页面后,呈现到用户客户端后,整个用户控件中的控件的名称将会有所变化,它们不再是你设计这个用户控件时的名称,而是有两个相关的名称:

id ―― 客户端可以通过这个id访问这个客户端控件,asp.net给每个控件输出的id形式为“用户控件id_此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id_下层用户控件id_此控件的id

name ―― 客户端也可以通过这个name来访问这个客户端控件,asp.net给每个控件输出的name“用户控件id:此控件的id”,如果是用户控件嵌套的情况,形式为“顶层用户控件id:下层用户控件id:此控件的id”。

 

例子:<input name="WebUserControl11:TextBox1" type="text" id="WebUserControl11_TextBox1" />

在设计用户控件时,放置了一个TextBoxidTexBox1,这个用户控件被放置到一个aspx页面,用户控件的idWebUserControl11,最后这个用户控件的TextBox到客户端后就是上面的这个样子的了。

 

客户端提交到服务端时是根据控件的name来提交的,也就是说,对服务端来讲,客户端的name是有意义的,id是不需要的。

在写客户端脚本时你不能预知你的用户控件将会是以什么id加入到aspx页面的,也不能预知用户控件被嵌套了多少层,所以你根本不能在设计时来参考这些控件。

幸好,asp.netwebcontrol htmlcontrol 的控件有个运行时属性 UniqueID,用来获取服务器控件的唯一的、以分层形式限定的标识符。对应到上面的那个例子,控件TextBox1UniqueID就是“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页面中,编译浏览这个页面,报一个脚本错误:缺少‘;’

把鼠标移到TextBox时,又报一个脚本错误:“缺少对象

 

检查发现,客户端引用的标示不能含有”:”符号,就是说在客户端不能用控件的name来参考。asp.netwebcontrol htmlcontrol 的控件还有个运行时属性 ClientID,它用来获取由 ASP.NET 生成的服务器控件标识符,也就是来获取控件的客户端id的,我们再改用这个属性来试一下:

 

document.all.<%= TextBox1.ClientID %>.value = "kent";

 

再运行,OK成功,当鼠标移动TextBox时,TextBox中出现了“kent”。

wpf中用户自定义控件UserControl中使用资源字典的问题

wpf中用户自定义控件UserControl中使用资源字典的问题tags: wpf c#今天自定义了一个控件,然后创建了一个资源字典来写Style,然后把编译好的dll文件加入另外一个工程,在另外一个...
  • whshiyun
  • whshiyun
  • 2017年09月25日 20:49
  • 525

C# 中用户控件中添加事件和使用

事件 用户控件 c#中用户控件 用户控件添加事件 自定义事件的使用 此处以TreeView用户控件为例:基本思路:1. 在SunSoftTree类中声明事件,如SelectedNodeChanged;...
  • forhiti
  • forhiti
  • 2007年06月26日 17:41
  • 2208

asp.net中动态加载用户控件的办法

很多网友在按钮的click事件中动态添加用户控件在页面回传后消失了或者就是用户控件中的按钮事件不能触发,下面是解决办法: (1) 首先添加一个用户控件:WebUserControl1.ascx ...
  • sweetsoft
  • sweetsoft
  • 2006年02月06日 13:22
  • 8511

VB.Net中用户控件的使用

机房重构中有这样
  • u013035924
  • u013035924
  • 2015年06月14日 19:08
  • 2252

创建WPF用户控件

创建WPF用户控件!纠正一些新手误区!
  • yangyisen0713
  • yangyisen0713
  • 2014年01月05日 17:19
  • 3195

asp.net 调用用户控件中的方法

一、用户控件ascx"C#" AutoEventWireup="true" CodeBehind="WebUserControl1.ascx.cs" Inherits="WebApplication4...
  • ikmb
  • ikmb
  • 2008年12月13日 13:37
  • 5086

asp.net获取用户控件的子控件的值

asp.net获取用户控件的子控件的值
  • qq_35844359
  • qq_35844359
  • 2017年03月28日 11:47
  • 516

使用MVC框架中要注意的问题:如何在页面和用户控件之间传递数据

在MVC中,页面被称为View,而用户控件则被称为PartialView。如何在它们之间传递数据呢? 默认情况下,PartialView能够访问到View里面的 ViewData. 如果页面在Rend...
  • u011411356
  • u011411356
  • 2016年03月14日 12:05
  • 808

WPF 用户控件

WPF中的自定义控件往往结合
  • sunny906
  • sunny906
  • 2014年07月23日 14:42
  • 1698

在VB中注册控件

Private Declare Function LoadLibraryA()Function LoadLibraryA Lib "kernel32" (ByVal lLibFileName As S...
  • null1
  • null1
  • 2007年12月14日 09:03
  • 1928
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用户控件中使用客户端脚本的控件名称问题
举报原因:
原因补充:

(最多只允许输入30个字)