美文网首页
easyui-tree扩展方法

easyui-tree扩展方法

作者: 佛系码农 | 来源:发表于2018-03-13 17:29 被阅读0次

/** * 1)扩展jquery easyui tree的节点检索方法。使用方法如下: * $("#treeId").tree("search", searchText); * 其中,treeId为easyui tree的根UL元素的ID,searchText为检索的文本。 * 如果searchText为空或"",将恢复展示所有节点为正常状态 */(function($) { $.extend($.fn.tree.methods, { /** * 扩展easyui tree的搜索方法 * param tree easyui tree的根DOM节点(UL节点)的jQuery对象 * param searchText 检索的文本 * param this-context easyui tree的tree对象 */ search: function(jqTree, searchText) { //easyui tree的tree对象。可以通过tree.methodName(jqTree)方式调用easyui tree的方法 var tree = this; //获取所有的树节点 var nodeList = getAllNodes(jqTree, tree); //如果没有搜索条件,则展示所有树节点 searchText = $.trim(searchText); if (searchText == "") { for (var i=0; i0) { var node = null; for (var i=0; i0) { for (var i=0; i (containerH - 30)) {

                    var scrollHeight = container.scrollTop() + nodeOffsetHeight - containerH + 30;

                    container.scrollTop(scrollHeight);

                }

            }

        }

    });

    /**

    * 展示搜索匹配的节点

    */

    function showMatchedNode(jqTree, tree, node) {

        //展示所有父节点

        $(node.target).show();

        $(".tree-title", node.target).addClass("tree-node-targeted");

        var pNode = node;

        while ((pNode = tree.getParent(jqTree, pNode.target))) {

            $(pNode.target).show();

        }

        //展开到该节点

        tree.expandTo(jqTree, node.target);

        //如果是非叶子节点,需折叠该节点的所有子节点

        if (!tree.isLeaf(jqTree, node.target)) {

            tree.collapse(jqTree, node.target);

        }

    }

    /**

    * 判断searchText是否与targetText匹配

    * param searchText 检索的文本

    * param targetText 目标文本

    * return true-检索的文本与目标文本匹配;否则为false.

    */

    function isMatch(searchText, targetText) {

        return $.trim(targetText)!="" && targetText.indexOf(searchText)!=-1;

    }

    /**

    * 获取easyui tree的所有node节点

    */

    function getAllNodes(jqTree, tree) {

        var allNodeList = jqTree.data("allNodeList");

        if (!allNodeList) {

            var roots = tree.getRoots(jqTree);

            allNodeList = getChildNodeList(jqTree, tree, roots);

            jqTree.data("allNodeList", allNodeList);

        }

        return allNodeList;

    }

    /**

    * 定义获取easyui tree的子节点的递归算法

    */

    function getChildNodeList(jqTree, tree, nodes) {

        var childNodeList = [];

        if (nodes && nodes.length>0) {

            var node = null;

            for (var i=0; i

相关文章

  • easyui-tree扩展方法

    /** * 1)扩展jquery easyui tree的节点检索方法。使用方法如下: * $("#treeId"...

  • easyui-Tree

    1、树节点前面是否显示复选框(接口初加载) 2、设置某个或某些节点前不显示复选框 3、解决点击展开节点重复加载数据...

  • Kotlin-面向对象-进阶

    扩展 扩展方法 Kotlin支持扩展方法和扩展属性。语法:被扩展的类/接口名.方法名() 父类不能使用子类的扩展方...

  • 扩展方法

    扩展方法: 扩展方法的类必须声明为static 扩展方法本身也必须声明为static 扩展方法必须包含关键字thi...

  • Swift- Extension

    扩展属性(只能是计算属性) 扩展构造器 扩展方法 通过扩展方法, 可以修改该实例self本身.但是方法前要加 mu...

  • ES6新增特性(二)

    ES6 的内置对象扩展 Array 的扩展方法 一、Array 的扩展方法 1. 扩展运算符(展开语法) 扩展运算...

  • JQuery写拓展

    基础 $.extend()扩展JQuery静态方法,$.fn.extend()扩展JQuery实例方法静态方法: ...

  • 23、扩展方法

    1.定义: 2.定于扩展方法 Personl类的定义 为Person类扩展方法 扩展方法被定义为静态方法,但它们是...

  • [IOS]优化UIButton的点击事件

    调用方法 添加扩展方法

  • kotlin中定义方法

    Kotlin 方法 扩展方法 方法内扩展有效 Lamda方法 最后一个表达式就是 lambda 的结果 方法作为参...

网友评论

      本文标题:easyui-tree扩展方法

      本文链接:https://www.haomeiwen.com/subject/bdazfftx.html