现在位置首页 / 项目实战 /正文

javascript/jquery怎么获取asp.net服务器控件的id

作者: IT小兵 | 2013年10月16日| 热度:℃ | 评论: |参与:

我们在asp.net中使用js/jquery进行验证,或者进行数据提交的时候,总会遇到js获取服务端控件的id问题。

服务端控件是指runat="server"控件。

注意事项:

1、如果是纯html控件:div、span等runat="server"后,也是本身你设置的ID,不用加ContentPlaceHolder1;

2、在单独的js文件中,你是无法使用<%=Me.txtTest.ClientID %>的方式获取服务端控件ID的。

下面就这个情况详细说明。

从外部的js文件中获取ASPX页面的控件ClientID(get control reference from external javascript) 

当使用MasterPage、UserControl等容器时,为了避免控件的重复命名,

asp.net会自动将容器中的控件生成一个ClientID(Control Tree中的可生成,否则不会生成)。

例如:ContentPlaceHolder1中的Button1默认情况下会生成“ctl00_ContentPlaceHolder1_Button1”的ClientID。

我们在Render出来的mark up中看到的也是这些ClientID。所以,当我们使用JavaScript对控件元素进行操作的时候,

必须使用ClientID来对控件进行查找。

1、页面内js的Inline情况下的解决方案

如果JavaScript代码写在.aspx文件中时,也就是Inline Script时。在页面生成的时候,

我们能够通过绑定机制将控件的ClientID绑定到页面Mark up中,故可使用:

document.getElementById("<%=Me.txtTest.ClientID %>" )
来获取一个控件的真实引用,当然,FindControl等方法也可以写在<%=...%>中用来绑定服务端数据到客户端。
2、外部js文件引用的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代码:
Default5.aspx
<%@ 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>
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>
<asp:Content ID="Content1" ContentPlaceHolderID="head" Runat="Server">
<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>
</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>
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";

我在实际项目中,封装了一个通用js函数,直接调用获取服务器控件id。

function $PageId(id) {

    return document.getElementById("ctl00_ContentPlaceHolder1_" + id);

}

大家酌情考虑,使用哪个方法了。


参考资料:http://www.cnblogs.com/6666/archive/2009/09/23/1572492.html 

转发注明来自:IT分享 http://www.suchso.com 


点击阅读本文所属分类的更多文章: 项目实战 。和高手一起交流:346717337
友荐云推荐

未注明转发、原文均为本站原创。分享本文请注明 原文链接

给您更多信息和帮助

在这里您可以找到更多:

技术交流群:346717337 Jquery插件交流

投稿:suchso@vip.qq.com

承接:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/业务咨询

抢天猫双11红包
推荐使用阿里云服务器
echarts教程系列
本月最热文章

微信扫一扫,徜徉悠嘻网,您的休闲乐园

微信公众号:快乐每一天

随机文章
标签

技术交流群:346717337

投稿:suchso@vip.qq.com

专业专注:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/付费问题咨询