| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 669 人关注过本帖
标题:<转>从外部的js文件中获取ASPX页面的控件ClientID(get control reference f ...
只看楼主 加入收藏
ghl2312
Rank: 4
等 级:业余侠客
威 望:2
帖 子:208
专家分:226
注 册:2008-7-10
结帖率:100%
收藏
 问题点数:0 回复次数:0 
<转>从外部的js文件中获取ASPX页面的控件ClientID(get control reference from external javasc
使用MasterPage、UserControl等容器时,为了避免控件的重复命名,会自动将容器中的控件生成一个ClientID(Control Tree中的可生成,否则不会生成)。
例如:ContentPlaceHolder1中的Button1默认情况下会生成“ctl00_ContentPlaceHolder1_Button1”的ClientID。
我们在Render出来的mark up中看到的也是这些ClientID。所以,当我们使用JavaScript对控件元素进行操作的时候,必须使用ClientID来对控件进行查找。
 
Inline情况下的解决方案
如果JavaScript代码写在.aspx文件中时,也就是Inline Script时。在页面生成的时候,我们能够通过绑定机制将控件的ClientID绑定到页面Mark up中,故可使用:
document.getElementById("<%=Me.txtTest.ClientID %>" )
来获取一个控件的真实引用,当然,FindControl等方法也可以写在<%=...%>中用来绑定服务端数据到客户端。
xternal JS情况下的解决方案
然而,部分情况下,为了解耦,我们常常把JavaScript单独写在.js文件中,再引用到aspx文件中去。这种情况下,.js文件内的代码不能通过<%=...%>来进行服务端数据的绑定,所以上面的方法是不能用的。
此时简单点的解决方案就是直接在JavaScript中写控件的ClientID,但这样增加了JS文件和ASPX的耦合度,非常不推荐使用。
我常用的方法有两种,在此抛砖引玉:
方案一:使用内联JS访问器
要想在外部JS中获得ASPX动态生成的ClientID,可以通过在ASPX页面中添加访问器的方式来实现,类似OO语言中的属性:
我们在Default5.aspx中添加如下代码:
作用:①声明getClientId访问器,并注册Button1的ClientID。②引用JScript.js文件
<script type="text/javascript">
    function getClientId()
     {
     var paraId1 = '<%= Button1.ClientID %>';
     return {Id1:paraId1};
     }
</script>
<script type="text/javascript" src="JScript.js"></script>
 
接下来,我们在JScript.js中,就可以这样来实现需求:
function ChangeText()
{
    var btn=document.getElementById(getClientId().Id1);
     btn.value="from extended js";
}
 
getClientId().Id1 貌似很OO,而且还支持VS2008很蹩脚的JS智能提示,打上“.”之后就可以在提示中选择Id1了
如果有多个控件需要注册,只需将他们注册到访问器中即可,下面是一个完整的Demo代码:
方案二:使用JS全局变量
还有一种方法也比较OO,就是使用JS全局变量,同样,也需要在Default5.aspx中添加一段JS代码,作为全局变量,来提供ClientID:
 
<script type="text/javascript">  
    var globals = {};
     globals.controlIdentities = {};
     globals.controlIdentities.someControl1 = '<%= Button1.ClientID %>';
     globals.controlIdentities.someControl2 = '<%= TextBox1.ClientID %>';
</script>
<script type="text/javascript" src="JScript.js"></script>
 
接下来,我们在JScript.js中,就可以这样来实现需求:
 
function ChangeText()
{
    var btn=document.getElementById(globals.controlIdentities.someControl1);
     btn.value="from extended js";
}
 
globals.controlIdentities.someControl1,同样,也支持VS2008很蹩脚的JS智能提示,打上“.”之后就可以在提示中选择someControl1了

搜索更多相关主题的帖子: get reference control ASPX ClientID 
2010-07-01 17:13
快速回复:<转>从外部的js文件中获取ASPX页面的控件ClientID(get control refere ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014161 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved