打造基于jQuery的高性能TreeView(asp.net)

2020-05-19 07:40:58易采站长站整理

, { name: “checkstate”, value: node.checkstate}];
return p;
}
function InitEvent(parent) {
var nodes = $(“li.bbit-tree-node>div”, parent);
nodes.each(function(e) {
$(this).hover(function() {
$(this).addClass(“bbit-tree-node-over”);
}, function() {
$(this).removeClass(“bbit-tree-node-over”);
})
.click(nodeclick)
.find(“img.bbit-tree-ec-icon”).each(function(e) {
if (!$(this).hasClass(“bbit-tree-elbow”)) {
$(this).hover(function() {
$(this).parent().addClass(“bbit-tree-ec-over”);
}, function() {
$(this).parent().removeClass(“bbit-tree-ec-over”);
});
}
});
});
}
function getck(items, c, fn) {
for (var i = 0, l = items.length; i < l; i++) {
items[i].checkstate == 1 && c.push(fn(items[i]));
if (items[i].ChildNodes != null && items[i].ChildNodes.length > 0) {
getck(items[i].ChildNodes, c, fn);
}
}
}
me[0].t = {
getSelectedNodes: function() {
var s = [];
getck(treenodes, s, function(item) { return item });
return s;
},
getSelectedValues: function() {
var s = [];
getck(treenodes, s, function(item) { return item.value });
return s;
},
getCurrentItem: function() {
return dfop.citem;
}
};
return me;
}
//获取所有选中的节点的Value数组
$.fn.getTSVs = function() {
if (this[0].t) {
return this[0].t.getSelectedValues();
}
return null;
}
//获取所有选中的节点的Item数组
$.fn.getTSNs = function() {
if (this[0].t) {
return this[0].t.getSelectedNodes();
}
return null;
}
$.fn.getTCT = function() {
if (this[0].t) {
return this[0].t.getCurrentItem();
}
return null;
}
})(jQuery);

第一步:自然是所有Jquery的控件的第一步都是搭这个架子,兼容JQuery和$避免闭包,避免和其他类库冲突,接受一个参数(是个对象)

;(function($) {
//也可以使用$.fn.extend(treeview:function(setting){})
$.fn.treeview = function(settings) {
}
})(jQuery);

那第二步:给控件加一些参数默认参数,同时能调用方法$.extend让最终调用时的参数覆盖默认的(如果没有则使用默认)

var dfop ={
method: “POST”,//默认采用POST提交数据
datatype: “json”,//数据类型是json
url: false,//异步请求的url
cbiconpath: “/images/icons/”,//checkbox icon的目录位置
icons: [“checkbox_0.gif”, “checkbox_1.gif”, “checkbox_2.gif”],//checkbxo三态的图片
showcheck: false, //是否显示checkbox
oncheckboxclick: false, //点击checkbox时触发的事件
onnodeclick: false,//点击node触发的时间
cascadecheck: true,//是否启用级联
data: null,//初始化数据
theme: “bbit-tree-arrows” //三种风格备选bbit-tree-lines ,bbit-tree-no-lines,bbit-tree-arrows