欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js獲取TreeView控件選中節(jié)點(diǎn)的Text和Value值的方法

 更新時(shí)間:2012年11月24日 13:49:46   作者:  
在實(shí)際項(xiàng)目中,遇到一個(gè)問題,首先彈出一個(gè)新窗口,新窗口中放了一個(gè)TreeView控件,現(xiàn)在要解決的是,如何單擊TreeView中一個(gè)節(jié)點(diǎn),返回Text和Value到父頁面并關(guān)閉該新窗口,本文將詳細(xì)介紹此方法的實(shí)現(xiàn)
在實(shí)際項(xiàng)目中,遇到一個(gè)問題,首先彈出一個(gè)新窗口,新窗口中放了一個(gè)TreeView控件,TreeView控件的數(shù)據(jù)綁定在我的上一篇隨筆(TreeView綁定XML數(shù)據(jù)源C#代碼示例)中有講到,現(xiàn)在要解決的是,如何單擊TreeView中一個(gè)節(jié)點(diǎn),返回Text和Value到父頁面并關(guān)閉該新窗口。
首先,在后臺代碼中為TreeView添加屬性onclick以支持TreeView的客戶端事件,代碼如下:
復(fù)制代碼 代碼如下:

if (!IsPostBack)
{
TreeView1.Attributes.Add("onclick", "ReturnValue()");//ReturnValue為javascript函數(shù)
BindTreeView();
}

那現(xiàn)在就要解決如何通過js獲得TreeView中被選中的那個(gè)節(jié)點(diǎn),腳本如下:
復(fù)制代碼 代碼如下:

function ReturnValue() {
var objNode = event.srcElement;
var unitid = event.srcElement.href;
if (objNode.tagName != "SPAN") {
return;
}
window.opener.document.getElementById("txtUnit").value = objNode.getAttribute("innerHtml");
window.opener.document.getElementById("txtUnitID").value = unitid;
window.close();
}

其實(shí)這里用了點(diǎn)小花招,因?yàn)槲覍?shí)在不知道在哪個(gè)屬性里能獲得綁定給TreeView的ValueField的值,所以,Value值我一并綁給了NavigateUrl,也就是寫黃色部分代碼的原因,Html代碼如下:
復(fù)制代碼 代碼如下:

<asp:TreeView ID="TreeView1" runat="server" ExpandDepth="1">
<DataBindings>
<asp:TreeNodeBinding TextField="NAME" ValueField="Value" NavigateUrlField="Value" SelectAction="None" />
</DataBindings>
</asp:TreeView>

紅色部分代碼是用來獲取TreeView上顯示文字的,因?yàn)槿绻闳ゲ榭丛次募脑?,你會發(fā)現(xiàn),TreeView的Text屬性值被放在了SPAN中。
綠色部分代碼是用來回填父頁面的,但是要注意的是,"txtUnit"必須是客戶端控件,因?yàn)槿绻欠?wù)器端控件,彈窗在編譯時(shí)會報(bào)不存在該控件。
這樣,我需要的功能就實(shí)現(xiàn)了!另外,有人可能會說,父頁面中用來裝載回填值的是客戶端控件,那如果要在服務(wù)器事件中使用怎么辦?也很簡單,C#代碼如下:
Request.Form["txtUnit"].ToString();
但是要注意了,這里的"txtUnit"可不是控件ID,而是name屬性了!

相關(guān)文章

最新評論