天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

從外部的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代碼:
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";
}

結束語:
在上面兩種方法中,也沒有真正的實現ASPx和js的完全解耦,所以,在js文件中,最好還是加上:
///<reference path="Default5.ASPx"/>

AspNet技術從外部的js文件中獲取ASPX頁面的控件ClientID,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 精品久久久久久综合网 | 人妻精品久久无码专区 | 中俄两军在日本海等上空战略巡航 | 扒开女人下面使劲桶动态图 | 一久久 | 狠狠色狠狠色综合曰曰 | 九九免费精品视频 | 中文字AV字幕在线观看 | 国产精品高清视亚洲一区二区 | 欧美亚洲国产专区在线 | 午夜在线播放免费人成无 | 国产在线观看不卡 | 一本之道高清视频在线观看 | 色视频色露露永久免费观看 | 玩高中女同桌肉色短丝袜脚文 | 国产传媒在线观看 | 一区二一二| 秋霞午夜理论理论福利无码 | 影视先锋男人无码在线 | 国产人妻777人伦精品HD | 亚洲成人免费在线 | 亚洲乱亚洲乱妇在线观看 | 久久精品国产亚洲AV忘忧草蜜臀 | 国产精品久久久久精品A片软件 | 亚洲精品中文字幕制 | 中文成人在线 | 欧美s00老人 | 好硬好湿好爽再深一点视频 | 4388成人 | 久久热在线视频精品 | 日本高清无卡码一区二区久久 | 国产成人在线视频播放 | 蜜臀AV人妻久久无码精品麻豆 | 成年人在线视频免费观看 | 善良的小峓子2在钱中文版女主角 | 国产午夜在线观看视频 | 国产成人综合在线观看 | 蜜桃成熟时2在线 | 亚洲欧美一级久久精品 | 久久婷婷五月综合色丁香 | 国产亚洲视频在线观看 |