从外部的js文件中获取ASPX页面的控件ClientID

 

前言

当使用MasterPage、UserControl等容器时,为了避免控件的重复命名,asp.net会自动将容器中的控件生成一个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等方法也可以写在<%=...%>中用来绑定服务端数据到客户端。

 

external JS情况下的解决方案

然而,部分情况下,为了解耦,我们常常把JavaScript单独写在.js文件中,再引用到aspx文件中去。这种情况下,.js文件内的代码不能通过<%=...%>来进行服务端数据的绑定,所以上面的方法是不能用的。

此时简单点的解决方案就是直接在JavaScript中写控件的ClientID,但这样增加了JS文件和ASPX的耦合度,非常不推荐使用。

我常用的方法有两种,在此抛砖引玉:

 

案例:

Default5.aspx是MasterPage.master 的内容页,本例中的主要文件。

JScript.js是一个外部的js文件,用来处理JavaScript操作。

Button1是Default5.aspx中的一个<ASP:Button>,用来显示效果。

Button2是Default5.aspx中的一个<input type=button>,用来触发JavaScript。

需求:点击Button2,将Button1上的文本改成“from extended js”

 

方案一:使用内联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代码:

 


<% @ Page Language = " C# "  MasterPageFile = " ~/MasterPage.master "  Title = " Untitled Page "   %>

< script  runat ="server" >

</ script >

< asp:Content  ID ="Content1"  ContentPlaceHolderID ="head"  Runat ="Server" >
< script  type ="text/javascript" >
    
function  getClientId()
    {
     
var  paraId1  =   ' <%= Button1.ClientID %> ' ; // 注册控件1

      var  paraId2  =   ' <%= TextBox1.ClientID %> ' ; // 注册控件2
      return  {Id1:paraId1,Id2:paraId2}; // 生成访问器
    }
</ script >

< script  type ="text/javascript"  src ="JScript.js" ></ script > //引用外部js
</ asp:Content >

< asp:Content  ID ="Content2"  ContentPlaceHolderID ="ContentPlaceHolder1"  Runat ="Server" >
    
< asp:TextBox  ID ="TextBox1"  runat ="server" ></ asp:TextBox >
    
< asp:Button  ID ="Button1"  runat ="server"  Text ="Button"   />
    
< input  id ="Button2"  type ="button"  value ="button"  onclick ="ChangeText();"   />
</ asp:Content >

 


function  ChangeText()
{
    
var  btn =
document.getElementById(getClientId().Id1);
    btn.value
= " from extended js "
;
    
    
var  btn =
document.getElementById(getClientId().Id2);
    btn.value
= " from extended js "
;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值