中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

用js腳本控制asp.net下treeview的NodeCheck的實(shí)現(xiàn)代碼

增加CheckBox聯(lián)動的情況選擇:
1.單選TreeView中的任一節(jié)點(diǎn)
2.當(dāng)一節(jié)點(diǎn)CheckBox屬性值改變時:子節(jié)點(diǎn)的CheckBox屬性值跟隨其改動,父節(jié)點(diǎn)不變;
父節(jié)點(diǎn)的所有子節(jié)點(diǎn)的CheckBox屬性值都為false時才為false;有一個子節(jié)點(diǎn)的CheckBox屬性值true時則為true.
3.當(dāng)一節(jié)點(diǎn)CheckBox屬性值改變時:子節(jié)點(diǎn)、父節(jié)點(diǎn)的CheckBox屬性值跟隨其改動;
父節(jié)點(diǎn)的所有子節(jié)點(diǎn)的CheckBox屬性值都為false時才為false;有一個子節(jié)點(diǎn)的CheckBox屬性值true時則為true.
Javascript代碼
復(fù)制代碼 代碼如下:
function OnTreeNodeChecked(id, type) {
//獲取觸發(fā)事件的對象
var element = window.event.srcElement;
//如果對象不是checkbox則不處理
if (!IsCheckBox(element))
return;
//獲取checked狀態(tài)
var isChecked = element.checked;
//獲取tree對象
var tree = TV2_GetTreeById(id);
//獲取element的相對結(jié)點(diǎn)(如果是葉結(jié)點(diǎn),則就為element,否則為其<A>結(jié)點(diǎn))
var node = TV2_GetNode(tree, element);
switch (type) {
case "1":
SetNodesUnChecked(tree);
element.checked = true;
break;
case "2":
TV2_SetChildNodesCheckStatus(node, isChecked);
break;
case "3":
TV2_SetChildNodesCheckStatus(node, isChecked);
var parent = TV2_GetParentNode(tree, node);
TV2_NodeOnChildNodeCheckedChanged(tree, parent, isChecked);
}
}
//set all nodes checkbox nochecked
function SetNodesUnChecked(TreeNode) {
var inputs = WebForm_GetElementsByTagName(TreeNode, "INPUT");
if (inputs == null || inputs.length == 0)
return;
for (var i = 0; i < inputs.length; i++) {
if (IsCheckBox(inputs[i]))
inputs[i].checked = false;
}
}
//set child nodes checkbox status
function TV2_SetChildNodesCheckStatus(node, isChecked) {
//返回當(dāng)前node所在的div層
var childNodes = TV2i_GetChildNodesDiv(node);
if (childNodes == null)
return;
var inputs = WebForm_GetElementsByTagName(childNodes, "INPUT");
if (inputs == null || inputs.length == 0)
return;
for (var i = 0; i < inputs.length; i++) {
if (IsCheckBox(inputs[i]))
inputs[i].checked = isChecked;
}
}
//change parent node checkbox status after child node changed
function TV2_NodeOnChildNodeCheckedChanged(tree, node, isChecked) {
if (node == null)
return;
var childNodes = TV2_GetChildNodes(tree, node);
if (childNodes == null || childNodes.length == 0)
return;
var isAllSame = true;
for (var i = 0; i < childNodes.length; i++) {
var item = childNodes[i];
var value = TV2_NodeGetChecked(item);
if (isChecked != value) {
isAllSame = false;
break;
}
}
var parent = TV2_GetParentNode(tree, node);
if (isAllSame) {
TV2_NodeSetChecked(node, isChecked);
TV2_NodeOnChildNodeCheckedChanged(tree, parent, isChecked);
}
else {
TV2_NodeSetChecked(node, true);
TV2_NodeOnChildNodeCheckedChanged(tree, parent, true);
}
}
//get node relative element(etc. checkbox)
function TV2_GetNode(tree, element) {
var id = element.id.replace(tree.id, "");
id = id.toLowerCase().replace(element.type, "");
id = tree.id + id;
var node = document.getElementById(id);
if (node == null) //leaf node, no "A" node
return element;
return node;
}
//get parent node
function TV2_GetParentNode(tree, node) {
var div = WebForm_GetParentByTagName(node, "DIV");
//The structure of node: <table>information of node</table><div>child nodes</div>
var table = div.previousSibling;
if (table == null)
return null;
return TV2i_GetNodeInElement(tree, table);
}
//get child nodes array
function TV2_GetChildNodes(tree, node) {
if (TV2_NodeIsLeaf(node))
return null;
var children = new Array();
var div = TV2i_GetChildNodesDiv(node);
var index = 0;
for (var i = 0; i < div.childNodes.length; i++) {
var element = div.childNodes[i];
if (element.tagName != "TABLE")
continue;
var child = TV2i_GetNodeInElement(tree, element);
if (child != null)
children[index++] = child;
}
return children;
}
function TV2_NodeIsLeaf(node) {
return !(node.tagName == "A"); //Todo
}
function TV2_NodeGetChecked(node) {
var checkbox = TV2i_NodeGetCheckBox(node);
return checkbox.checked;
}
function TV2_NodeSetChecked(node, isChecked) {
var checkbox = TV2i_NodeGetCheckBox(node);
if (checkbox != null)
checkbox.checked = isChecked;
}
function IsCheckBox(element) {
if (element == null)
return false;
return (element.tagName == "INPUT" && element.type.toLowerCase() == "checkbox");
}
//get tree
function TV2_GetTreeById(id) {
return document.getElementById(id);
}
//////////////////////////////////////////////////////////////////////////////////////////////
//private mothods, with TV2i_ prefix
//////////////////////////////////////////////////////////////////////////////////////////////
//get div contains child nodes
function TV2i_GetChildNodesDiv(node) {
//如果node.tagName == "A"則不處理
if (TV2_NodeIsLeaf(node))
return null;
var childNodsDivId = node.id + "Nodes";
return document.getElementById(childNodsDivId);
}
//find node in element
function TV2i_GetNodeInElement(tree, element) {
var node = TV2i_GetNodeInElementA(tree, element);
if (node == null) {
node = TV2i_GetNodeInElementInput(tree, element);
}
return node;
}
//find "A" node
function TV2i_GetNodeInElementA(tree, element) {
var as = WebForm_GetElementsByTagName(element, "A");
if (as == null || as.length == 0)
return null;
var regexp = new RegExp("^" + tree.id + "n//d+$");
for (var i = 0; i < as.length; i++) {
if (as[i].id.match(regexp)) {
return as[i];
}
}
return null;
}
//find "INPUT" node
function TV2i_GetNodeInElementInput(tree, element) {
var as = WebForm_GetElementsByTagName(element, "INPUT");
if (as == null || as.length == 0)
return null;
var regexp = new RegExp("^" + tree.id + "n//d+");
for (var i = 0; i < as.length; i++) {
if (as[i].id.match(regexp)) {
return as[i];
}
}
return null;
}
//get checkbox of node
function TV2i_NodeGetCheckBox(node) {
if (IsCheckBox(node))
return node;
var id = node.id + "CheckBox";
return document.getElementById(id);
}

html代碼
復(fù)制代碼 代碼如下:
<ASP:TreeView ID="TreeView1" runat="server" ImageSet="Msdn" ShowCheckBoxes="All"
ShowLines="True" BorderWidth="0px" Height="430px" Width="250px" Font-Size="Small"
OnClick="OnTreeNodeChecked()">
</ASP:TreeView>

JavaScript技術(shù)用js腳本控制asp.net下treeview的NodeCheck的實(shí)現(xiàn)代碼,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 欧美久久一区二区三区 | 日韩免费av一区二区 | 久久午夜精品 | 成人免费大片黄在线播放 | 福利视频一区二区三区 | www.日韩 | 中文在线一区 | 视频在线h | 91在线看片 | 日本久久综合网 | 久草.com | 成人在线免费网站 | 成人精品国产一区二区4080 | 91中文视频 | 一区二区三区四区国产 | 久久r免费视频 | 久久91精品国产 | 一区二区三区免费在线观看 | 欧美一区2区三区3区公司 | 日韩欧美在线观看 | 久久久一区二区三区四区 | 毛片一级片 | 久久天天躁狠狠躁夜夜躁2014 | 成人在线观看免费 | 九色在线观看 | 久久精品青青大伊人av | 99pao成人国产永久免费视频 | 久久黄色网 | 羞羞色影院 | 国产精品国产三级国产aⅴ入口 | 情侣黄网站免费看 | 一级全黄视频 | 亚洲色片网站 | 国产福利在线 | 成人精品一区二区 | 午夜视频网 | 伊人狠狠干 | 999久久久 | 亚洲精品日韩精品 | 日韩欧美视频免费在线观看 | 羞视频在线观看 |