【ztree系列】树节点的模糊查询

【ztree系列】树节点的模糊查询以前设计模糊查询的功能,一般都是针对表格来做的,还真没考虑过对tree进行模糊查询,也可能是因为遇到的数据量还没到头疼的程度吧。为了完美的实现模糊查询的效果,搞了半天css,对输入框显示效果的设置更是修改了n多次,什么半圆角、边框、光影。。。真佩服我这颗屡试屡换的小心脏啊一、页面设计对于搜索功能,首先要有输入框,用于接收输入内容;然后就是显示搜索结果用的标签,控制焦点用的上移下动按钮。其实

大家好,又见面了,我是你们的朋友全栈君。

       以前设计模糊查询的功能,一般都是针对表格来做的,还真没考虑过对tree进行模糊查询,也可能是因为遇到的数据量还没到头疼的程度吧。为了完美的实现模糊查询的效果,搞了半天css,对输入框显示效果的设置更是修改了n多次,什么半圆角、边框、光影。。。真佩服我这颗屡试屡换的小心脏啊

一、页面设计

        对于搜索功能,首先要有输入框,用于接收输入内容;然后就是显示搜索结果用的标签,控制焦点用的上移下动按钮。其实,也没必要这么复杂,单纯一个输入款也ok的,但是这么简陋的搜索真的有点不太好。。。

<div class="col-md-3 sidebar">
    <div class="row">
        <div>
            <input type="text"  id="key" class="empty form-control" placeholder="Search..." οnkeyup="callNumber()">
        </div>
        <div>
            <label type="text"  id="resultKey" class="form-control"οnclick="changeFocus()" >
                <div>
                    <a id="clickUp" class="glyphicon glyphicon-menu-up" οnclick="clickUp()"></a>
                    <a id="clickDown" class="glyphicon glyphicon-menu-down" οnclick="clickDown()"></a>
                </div>
                <label id="number"></label>
            </label>
        </div>
    </div>
    <ul id="tree" class="ztree"></ul>
</div>
【ztree系列】树节点的模糊查询

二、搜索结果的显示

       关于搜索结果的显示,刚开始考虑了两种:只显示结果,对于这种,当有搜索结果时我们就看不到树结构了,没有树结构则会显得信息凌乱,所以放弃了这种方式;第二种是高亮所有搜索信息,如果搜索结果所在的父节点是关闭的,则自动打开。

       在页面加载时,给搜索框再绑定一些事件

$(document).ready(function(){
    $.fn.zTree.init($("#tree"), setting, zNodes);
    document.getElementById("key").value = ""; //清空搜索框中的内容
    //绑定事件
    key = $("#key");
    key.bind("focus", focusKey)
        .bind("blur", blurKey)
        .bind("propertychange", searchNode) //property(属性)change(改变)的时候,触发事件
        .bind("input", searchNode);
});

       为了让搜索功能使用起来更省事,我把真正对树执行搜索功能的操作放在了搜索框的“键盘释放”事件上,在这里用了ztree的一个函数来得到搜索的结果,并赋给一个数组变量

var lastValue = "", nodeList = [], fontCss = {};
//键盘释放:当输入框的键盘按键被松开时,把查询到的数据结果显示在标签中
function callNumber(){
    var zTree = $.fn.zTree.getZTreeObj("tree");

    //如果结果有值,则显示比例;如果结果为0,则显示"[0/0]";如果结果为空,则清空标签框;
    if(nodeList.length){
        //让结果集里边的第一个获取焦点(主要为了设置背景色),再把焦点返回给搜索框
        zTree.selectNode(nodeList[0],false );
        document.getElementById("key").focus();

        clickCount=1; //防止重新输入的搜索信息的时候,没有清空上一次记录

        //显示当前所在的是第一条
        document.getElementById("number").innerHTML="["+clickCount+"/"+nodeList.length+"]";

    }else if(nodeList.length == 0){
        document.getElementById("number").innerHTML="[0/0]";
        zTree.cancelSelectedNode(); //取消焦点
    }

    //如果输入框中没有搜索内容,则清空标签框
    if(document.getElementById("key").value ==""){
        document.getElementById("number").innerHTML="";
        zTree.cancelSelectedNode();
    }
}
function focusKey(e) {
    if (key.hasClass("empty")) {
        key.removeClass("empty");
    }
}
function blurKey(e) {
    if (key.get(0).value === "") {
        key.addClass("empty");
    }
}
//搜索节点
function searchNode(e) {
    var zTree = $.fn.zTree.getZTreeObj("tree");
    var value = $.trim(key.get(0).value);
    var keyType = "name";

    if (key.hasClass("empty")) {
        value = "";
    }
    if (lastValue === value) return;
    lastValue = value;
    if (value === ""){
        updateNodes(false);
        return;
    };
    nodeList = zTree.getNodesByParamFuzzy(keyType, value); //调用ztree的模糊查询功能,得到符合条件的节点
    updateNodes(true); //更新节点
}

       获得搜索的节点信息后,再对ztree执行更新操作,即修改搜索结果中节点的文字样式

//高亮显示被搜索到的节点
function updateNodes(highlight) {
    var zTree = $.fn.zTree.getZTreeObj("tree");
    for( var i=0, l=nodeList.length; i<l; i++) {
        nodeList[i].highlight = highlight; //高亮显示搜索到的节点(highlight是自己设置的一个属性)
        zTree.expandNode(nodeList[i].getParentNode(), true, false, false); //将搜索到的节点的父节点展开
        zTree.updateNode(nodeList[i]); //更新节点数据,主要用于该节点显示属性的更新
    }
}

       修改文字样式,主要调用的是ztree的ztree.setting.view.fontCss所定义的函数来实现,想换用其它颜色的修改这个函数就行了,主要用了一个三目运算

//设置颜色
function getFontCss(treeId, treeNode) {
    return (!!treeNode.highlight) ? {color:"#A60000", "font-weight":"bold"} : {color:"#333", "font-weight":"normal"};
}

三、上下移动按钮

       在树结构较大,且搜索数量过多时,单纯的高亮搜索结果就不太能满足我们的要求了,所以这里提供了上下移动按钮,且提供标签框来动态的显示搜索结果的数据

//点击向上按钮时,将焦点移向上一条数据
function clickUp(){
    var zTree = $.fn.zTree.getZTreeObj("tree");
    //如果焦点已经移动到了最后一条数据上,就返回第一条重新开始,否则继续移动到下一条
    if(nodeList.length==0){
        alert("没有搜索结果!");
        return ;
    }else if(clickCount==1) {
        alert("您已位于第一条记录上!");
        return;
        //让结果集里边的下一个节点获取焦点(主要为了设置背景色),再把焦点返回给搜索框
        //zTree.selectNode(nodeList[clickCount], false)
    }else{
        //让结果集里边的第一个获取焦点(主要为了设置背景色),再把焦点返回给搜索框
        zTree.selectNode(nodeList[clickCount], false);
        clickCount --;
    }
    document.getElementById("key").focus();
    //显示当前所在的是条数
    document.getElementById("number").innerHTML = "[" + clickCount + "/" + nodeList.length + "]";
}
//点击向上按钮时,将焦点移向下一条数据
function clickDown(){
    var zTree = $.fn.zTree.getZTreeObj("tree");
    //如果焦点已经移动到了最后一条数据上,则提示用户(或者返回第一条重新开始),否则继续移动到下一条
    if(nodeList.length==0){
        alert("没有搜索结果!");
        return ;
    }else if(nodeList.length==clickCount)
    {
        alert("您已位于最后一条记录上!")
        return;
    }else{
        //让结果集里边的第一个获取焦点(主要为了设置背景色),再把焦点返回给搜索框
        zTree.selectNode(nodeList[clickCount], false)
        clickCount ++;
    }
    document.getElementById("key").focus();
    //显示当前所在的条数
    document.getElementById("number").innerHTML = "[" + clickCount + "/" + nodeList.length + "]";
}

        当搜索“巴”时,自动展开节点,默认第一个搜索结果呈选中状态;点击上下移动按钮时,树上的焦点自动更换,显示搜索条数比例的标签框中的内容也自动更换。当没有搜索结果时,显示的搜索条数比例为[0/0];当输入框为空时,显示搜索条数比例的标签框自动清空。

【ztree系列】树节点的模糊查询       【ztree系列】树节点的模糊查询

小结:

        对页面上数据的查询有很多种,现在最常用的就是模糊查询,原理都差不多,所以上边只选择了这种,用ztree自带的模糊查询就可以实现了。这里主要做的优化是针对搜索结果的显示效果,以及对开始执行搜索操作的触发事件的调整。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/139365.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 基础概念 — SOP「建议收藏」

    基础概念 — SOP「建议收藏」StandardOperationProcedure定义精髓企业sop提高企业运行效率提升企业运行效果步骤1)确定流程2)明确步骤3)制定SOP4)执行操作定义标准作业程序将某一事件的标准操作步骤和要求以统一的格式扫描出来,用来指导和规范日常的工作精髓将细节进行量化即对某一程序中的关键控制点进行细化和量化企业sop提高企业运行效率企业的日常工作有两个基本的特征,一是许多岗位的人员经常会发生变动,二是一些日常的工作的基本作业程序相对比较稳定。通过SOP对细节进行量化和规范例如:在一

    2022年5月9日
    49
  • MySql多表、多字段分组,多字段去重「建议收藏」

    MySql多表、多字段分组,多字段去重「建议收藏」直接了当上SQL SELECT a.字段1, a.字段2, b.字段1, COUNT(DISTINCT a.字段1),COUNT(DISTINCT b.字段1) FROM xs_highway_transport_log a LEFT JOIN b表 b ON b.id = a.main GROUP BY a.字段1 ,b.字段1// 这行为分组直接这样 即可实现 多字段去重情况。同时可以配合having过滤分组,也可以在 分组

    2022年8月19日
    8
  • QFile源码学习笔记

    QFile源码学习笔记之前简单介绍了Qt读写文件Qt之读写文件http://blog.csdn.net/zhuyunfei/article/details/51249378这里记录下自己学习QFile的笔记。1.在Qt之读写文件中,在打开模式中指定未Append模式,发现如果文件不存在会自动创建新文件,在QFile的源码中找到了原因,在open函数的定义中都有如下语句if(mode&Append)mode

    2022年6月11日
    28
  • jvm之java类加载机制和类加载器(ClassLoader)的详解

    jvm之java类加载机制和类加载器(ClassLoader)的详解当程序主动使用某个类时,如果该类还未被加载到内存中,则JVM会通过加载、连接、初始化3个步骤来对该类进行初始化。如果没有意外,JVM将会连续完成3个步骤,所以有时也把这个3个步骤统称为类加载或类初始化。一、类加载过程1.加载加载指的是将类的class文件…

    2022年6月10日
    33
  • acwing-2172. Dinic/ISAP求最大流[通俗易懂]

    acwing-2172. Dinic/ISAP求最大流[通俗易懂]给定一个包含 n 个点 m 条边的有向图,并给定每条边的容量,边的容量非负。图中可能存在重边和自环。求从点 S 到点 T 的最大流。输入格式第一行包含四个整数 n,m,S,T。接下来 m 行,每行三个整数 u,v,c,表示从点 u 到点 v 存在一条有向边,容量为 c。点的编号从 1 到 n。输出格式输出点 S 到点 T 的最大流。如果从点 S 无法到达点 T 则输出 0。数据范围2≤n≤10000,1≤m≤100000,0≤c≤10000,S≠T输入样例:7 14 1 71

    2022年8月10日
    5
  • ETL开发面试题集

    ETL开发面试题集ETL讲解(很详细!!!)ETL是将业务系统的数据经过抽取、清洗转换之后加载到数据仓库的过程,目的是将企业中的分散、零乱、标准不统一的数据整合到一起,为企业的决策提供分析依据。ETL是BI项目重要的一个环节。通常情况下,在BI项目中ETL会花掉整个项目至少1/3的时间,ETL设计…

    2022年6月13日
    73

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号