前言

扩展自$.fn.combo.defaults和$.fn.tree.defaults。使用$.fn.combotree.defaults重写默认值对象。下载该插件翻译源码

树形下拉框结合选择控件和下拉树控件。它与combobox(下拉列表框)类似,但是将下拉列表框的列表替换成了树形控件。该控件支持树状态复选框,方便多选操作

依赖关系

  • combo
  • tree

源码

/**
* jQuery EasyUI 1.3.2
*
*翻译: qq 1364386878 下拉树
*/
(function ($) {
//设置大小
function setSize(jq) {
var options = $.data(jq, "combotree").options;
var combotree = $.data(jq, "combotree").tree;
$(jq).addClass("combotree-f");
$(jq).combo(options);
var panel = $(jq).combo("panel");
if (!combotree) {
combotree = $("<ul></ul>").appendTo(panel);
$.data(jq, "combotree").tree = combotree;
}
combotree.tree($.extend({},
options, {
checkbox: options.multiple,
onLoadSuccess: function (node, data) {
var values = $(jq).combotree("getValues");
if (options.multiple) {
var checkedNodes = combotree.tree("getChecked");
for (var i = 0; i < checkedNodes.length; i++) {
var id = checkedNodes[i].id;
(function () {
for (var i = 0; i < values.length; i++) {
if (id == values[i]) {
return;
}
}
values.push(id);
})();
}
}
$(jq).combotree("setValues", values);
options.onLoadSuccess.call(this, node, data);
},
onClick: function (node) {
select(jq);
$(jq).combo("hidePanel");
options.onClick.call(this, node);
},
onCheck: function (node, node) {
select(jq);
options.onCheck.call(this, node, node);
}
}));
};
//选择
function select(jq) {
var options = $.data(jq, "combotree").options;
var combotree = $.data(jq, "combotree").tree;
var vv = [], ss = [];
if (options.multiple) {
var checkedNode = combotree.tree("getChecked");
for (var i = 0; i < checkedNode.length; i++) {
vv.push(checkedNode[i].id);
ss.push(checkedNode[i].text);
}
} else {
var checkedNode = combotree.tree("getSelected");
if (checkedNode) {
vv.push(checkedNode.id);
ss.push(checkedNode.text);
}
}
$(jq).combo("setValues", vv).combo("setText", ss.join(options.separator));
};
//设置数组值
function setValues(jq, values) {
var options = $.data(jq, "combotree").options;
var combotree = $.data(jq, "combotree").tree;
combotree.find("span.tree-checkbox").addClass("tree-checkbox0").removeClass("tree-checkbox1 tree-checkbox2");
var vv = [], ss = [];
for (var i = 0; i < values.length; i++) {
var v = values[i];
var s = v;
var node = combotree.tree("find", v);
if (node) {
s = node.text;
combotree.tree("check", node.target);
combotree.tree("select", node.target);
}
vv.push(v);
ss.push(s);
}
$(jq).combo("setValues", vv).combo("setText", ss.join(options.separator));
};
//实例化下拉树
$.fn.combotree = function (target, parm) {
if (typeof target == "string") {
var method = $.fn.combotree.methods[target];
if (method) {
return method(this, parm);
} else {
return this.combo(target, parm);
}
}
target = target || {};
return this.each(function () {
var combotree = $.data(this, "combotree");
if (combotree) {
$.extend(combotree.options, target);
} else {
$.data(this, "combotree", {
options: $.extend({},
$.fn.combotree.defaults,
$.fn.combotree.parseOptions(this),
target)
});
}
setSize(this);
});
};
//默认方法
$.fn.combotree.methods = {
//返回属性对象
options: function (jq) {
var options = $.data(jq[0], "combotree").options;
options.originalValue = jq.combo("options").originalValue;
return options;
},
//返回树形对象
tree: function (jq) {
return $.data(jq[0], "combotree").tree;
},
//读取本地树形数据
loadData: function (jq, data) {
return jq.each(function () {
var options = $.data(this, "combotree").options;
options.data = data;
var tree = $.data(this, "combotree").tree;
tree.tree("loadData", data);
});
},
//再次请求远程树数据。通过'url'参数重写原始URL值
reload: function (jq, url) {
return jq.each(function () {
var options = $.data(this, "combotree").options;
var tree = $.data(this, "combotree").tree;
if (url) {
options.url = url;
}
tree.tree({ url: options.url });
});
},
//设置组件值数组
setValues: function (jq, values) {
return jq.each(function () {
setValues(this, values);
});
},
//设置组件值。
setValue: function (jq, value) {
return jq.each(function () {
setValues(this, [value]);
});
},
//清空控件的值
clear: function (jq) {
return jq.each(function () {
var tree = $.data(this, "combotree").tree;
tree.find("div.tree-node-selected").removeClass("tree-node-selected");
var cc = tree.tree("getChecked");
for (var i = 0; i < cc.length; i++) {
tree.tree("uncheck", cc[i].target);
}
$(this).combo("clear");
});
},
//重置
reset: function (jq) {
return jq.each(function () {
var options = $(this).combotree("options");
if (options.multiple) {
$(this).combotree("setValues", options.originalValue);
} else {
$(this).combotree("setValue", options.originalValue);
}
});
}
};
//解析器
$.fn.combotree.parseOptions = function (target) {
return $.extend({}, $.fn.combo.parseOptions(target),
$.fn.tree.parseOptions(target));
};
//默认属性、事件 继承comb和tree的
$.fn.combotree.defaults = $.extend({},
$.fn.combo.defaults,
$.fn.tree.defaults,
{
//定义用户是否可以直接输入文本到字段中
editable: false
});
})(jQuery);

示例代码

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Basic ComboTree - jQuery EasyUI Demo</title>
<link rel="stylesheet" type="text/css" href="../../themes/default/easyui.css">
<link rel="stylesheet" type="text/css" href="../../themes/icon.css">
<link rel="stylesheet" type="text/css" href="../demo.css">
<script type="text/javascript" src="../../jquery-1.8.0.min.js"></script>
<script src="../../plugins2/jquery.parser.js"></script>
<script src="../../plugins2/jquery.validatebox.js"></script>
<script src="../../plugins2/jquery.panel.js"></script>
<script src="../../plugins2/jquery.combo.js"></script>
<script src="../../plugins2/jquery.draggable.js"></script>
<script src="../../plugins2/jquery.droppable.js"></script>
<script src="../../plugins2/jquery.tree.js"></script>
<script src="../../plugins2/jquery.combotree.js"></script>
</head>
<body>
<h2>Basic ComboTree</h2>
<div class="demo-info">
<div class="demo-tip icon-tip"></div>
<div>Click the right arrow button to show the tree panel.</div>
</div>
<div style="margin:10px 0"></div>
<input class="easyui-combotree" data-options="url:'../combotree/tree_data1.json',required:true" style="width:200px;"> </body>
</html>

插件效果

easyui源码翻译1.32--ComboTree(树形下拉框)的更多相关文章

  1. easyui源码翻译1.32+API翻译全篇导航 (提供下载源码)

    前言 EasyUI每个组件都会有 属性.方法.事件 属性 所有的属性都定义在jQuery.fn.{plugin}.defaults里面.例如,对话框属性定义在jQuery.fn.dialog.defa ...

  2. easyui源码翻译1.32--TreeGrid(树形表格)

    前言 扩展自$.fn.datagrid.defaults.使用$.fn.treegrid.defaults重写默认值对象.下载该插件翻译源码 树形表格用于显示分层数据表格.它是基于数据表格.组合树控件 ...

  3. EasyUI:combotree(树形下拉框)复选框选中父节点(子节点的状态也全部选中)输入框中只显示父节点的文本值

    参考: https://blog.csdn.net/weixin_43236850/article/details/100320564

  4. easyui源码翻译1.32--Combo(自定义下拉框)

    前言 扩展自$.fn.validatebox.defaults.使用$.fn.combo.defaults重写默认值对象.下载该插件翻译源码 自定义下拉框显示一个可编辑的文本框和下拉面板在html页面 ...

  5. 雷林鹏分享:jQuery EasyUI 表单 - 创建树形下拉框

    jQuery EasyUI 表单 - 创建树形下拉框 树形下拉框(ComboTree)是一个带有下列树形结构(Tree)的下拉框(ComboBox).它可以作为一个表单字段进行使用,可以提交给远程服务 ...

  6. Ext5实现树形下拉框ComboBoxTree

    最近为了实现一个属性下拉框被Ext框架折腾了好几天.. 所以,首先要说的是,不管你要做什么系统.强烈建议你不要选择Ext.据我这几天的搜索,应该这个框架现在用的人也很少了. Ext框架的缺陷:框架沉重 ...

  7. Vue实现树形下拉框

    Vue自身并没有实现树形下拉框的组件,找了很多资料,最后在Github上找了个插件vue-treeselect,功能还是比较全的,模糊搜索.多选.延迟加载.异步搜索.排序,自定义.Vuex支持等等.这 ...

  8. Dorado开发——树形下拉框

    最近在学习Dorado开发的过程中,遇到了一个问题,Dorado的树形下拉框选择:Dorado默认情况下父节点和子节点都是可选的,而我要实现的是父节点不可选. 解决办法:在下拉框中,判断父子节点,点击 ...

  9. easyui源码翻译1.32--datagrid(数据表格)

    前言 此前网上有easyui1.25的源码  应该算是比较老的版本  之后又经历了1.26 . 1.3. 1.31. 1.32 .1.33.1.34  1.33开始支持css3 算是又一个转折  但是 ...

随机推荐

  1. poj2594 (最小路径覆盖 + floyd)

    题目链接  http://poj.org/problem?id=2594) 题目大意: 一个有向图中, 有若干条连接的路线, 问最少放多少个机器人,可以将整个图上的点都走过. 最小路径覆盖问题. 分析 ...

  2. linux 文本编辑器 vim 基本操作

    三种模式之间转换: 一般模式 可用于光标移动.复制粘贴.查找替换 "vim.txt"表示文件名 8L 表示8行 , 80C 表示80个字符 移动光标常用操作: h .j. k. l ...

  3. C#多线程同步

    在编写多线程程序时无可避免会碰到线程的同步问题.什么是线程的同步呢? 举个例子:假如在一个公司里面有一个变量记录某人T的工资count=100,有两个主管A和B(即工作线程)在早一些时候拿了这个变量的 ...

  4. Ubuntu 14.04 eclipse 提示框背景色更改

    首先查看系统设置->外观->主题. 不同的主题需要更改的文件不同 sudo vim /usr/share/themes/主题(就是刚才主题的名字,ubuntu14.04默认是Ambianc ...

  5. LeetCode FindMinimuminRotatedSorteArray &&FindMinimuminRotatedSorteArray2

    LeetCode上这两道题主要是使用二分搜索解决,是二分搜索算法的一个应用,根据条件每次舍弃一半,保留一半. 首先第一题: FindMinimuminRotatedSorteArray(时间复杂度为二 ...

  6. 云盾正常扫描云服务器的IP是什么

    问题:云盾正常扫描云服务器的IP是什么?   解答:云盾扫描云服务器的的IP段固定为    42.120.145.0/24 110.75.105.0/24 110.75.185.0/24 110.75 ...

  7. 【Linux工具】svn命令行使用实例

    引言 网上有这么多介绍 svn 使用的文章,为什么还要写?因为它们深入不浅出,平铺不分类,理论不实际,看完也记不住. 本文先介绍基本用法,后进行实例演练.不求大而全,只求熟练常用,自行用 svn he ...

  8. MySQL复制(三) --- 高可用性和复制

    实现高可用性的原则很简单: 冗余(Redundancy):如果一个组件出现故障,必须有一个备用组件.这个备用组件可以是standing by的,也可以是当前系统部署中的一部分. 应急计划(Contig ...

  9. aspx与mvc页面验证码

    验证码类代码 using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Dr ...

  10. CSS display:inline和float:left两者区别探讨

     本文和大家重点讨论一下CSS display:inline和float:left两者的区别,CSS display是指显示状态,inline表示内联,特点是紧贴着前一个内联元素,通常默认的内联元素有 ...