从外部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中的一个 ,用来显示效果。

Button2是Default5.aspx中的一个 ,用来触发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代码:

Default5.aspx

代码如下:

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

<script runat=”server”>

</script>

<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

JScript.js

function ChangeText()

{

var btn=document.getElementById(getClientId().Id1);

btn.value=”from extended js”;

var btn=document.getElementById(getClientId().Id2);

btn.value=”from extended js”;

}

方案二:使用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了

下面是一个完整的Demo代码:

Default5.aspx

代码如下:

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

<script runat=”server”>

</script>

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

var txt=document.getElementById(globals.controlIdentities.someControl2);

btn.value=”from extended js”;

}

结束语:

在上面两种方法中,也没有真正的实现aspx和js的完全解耦,所以,在js文件中,最好还是加上:

///

转载请注明:代码学堂>编程开发 > ASP.NET > 从外部js文件中获取ASPX页面的控件ClientID的方法

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!10210454@qq.com
2. 本站不保证所提供所有下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理,有奖励!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有RB奖励和额外RMB收入!

磊宇堂正在使用的服务器 维护管理由磊宇云服务器提供支持

磊宇堂 » 从外部js文件中获取ASPX页面的控件ClientID的方法

提供最优质的资源集合

立即查看 了解详情