ID,ClientID和UniqueID - .net语言 -

ID,ClientID和UniqueID

时间:2010-01-27 00:02:11   来源:   评论:加载中...   点击:加载中...
在ASP.NET 的服务器端控件中有三种关于 ID 的属性,即 ID, ClientID 和 UniqueID。ID 表示控件的服务器端编程的标识符,我们写"服...

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

 

></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";
}
 

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

 

></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>


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文件中,最好还是加上:

-->///<reference path="Default5.aspx"/>
上面的方法是我常用的,今天仓促的总结了一下,希望在此能够抛砖引玉,谢谢!

 



相关热词搜索:

 
上一篇:DataGrid的自动编号问题
下一篇:C#中COOKIES的实现存取
收藏 将此文推荐给朋友
分享到: