chnking的专栏

心无旁骛,专注于biztalk......

用户操作
[即时聊天] [发私信] [加为好友]
金剑忠ID:chnking
32636次访问,排名3777,好友0人,关注者2人。
chnking的文章
原创 55 篇
翻译 1 篇
转载 0 篇
评论 109 篇
chnking的公告
版权说明: 可以自由的拷贝、转载、散发、使用本人的文章。但请注明出处和作者。
QQ:362682
MSN:chnking@hotmail.com
biztalk QQ群:7276643
最近评论
出会い関係者:出会いセックス素人
ko_rela:鍵屋なら、プレスリリースなら、ウォーターサーバー 比較なら、ウォーターサーバー ランキング……
alkjdi:レーシック
レーシック
レーシック
オナニー出会いエロ
人事課:エロSEX風俗
文章分类
收藏
    相册
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 用户控件中使用客户端脚本的控件名称问题收藏

    新一篇: table的宽度,单元格内换行问题 | 旧一篇: 页面装载用户控件时的事件顺序

     

    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”。

    发表于 @ 2003年07月28日 08:43:00|评论(loading...)|编辑

    新一篇: table的宽度,单元格内换行问题 | 旧一篇: 页面装载用户控件时的事件顺序

    评论

    #在线等 发表于2004-11-23 15:38:00  IP: 218.80.197.*
    <script language=javascript>

    <!--

    function over()

    {

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

    }

    //-->

    </script>
    要是这一段是.net自己产生的,应该怎么办呢?
    #在线等 发表于2004-11-23 15:38:00  IP: 218.80.197.*
    <script language=javascript>

    <!--

    function over()

    {

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

    }

    //-->

    </script>
    要是这一段是.net自己产生的,应该怎么办呢?
    #c_shop_p 发表于2007-04-24 17:07:21  IP: 10.167.130.*
    我也遇到了这个问题,看到你这篇文章,让我收益非浅啊
    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © chnking