欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

案例详解_使用javascript编写用户列表组合条件筛选

程序员文章站 2022-04-04 13:49:36
...
本文介绍如何使用原生js编写用户列表组合条件筛选?可以通过按钮和输入文字进行组合条件筛选的功能,以下用代码将详细介绍,先上一张效果图:

案例详解_使用javascript编写用户列表组合条件筛选 这里使用数组模拟后台数据(可用ajax请求后台数据):

var person = [
    { name: '王小妹', src: '01pic.jpg', sex: 'male', des: '漂亮的妹子'},
    { name: '金小妹', src: '02pic.jpg', sex: 'male', des: '漂亮的程序媛'},
    { name: '陈小华', src: '07pic.jpg', sex: 'female', des: '相互学习'},
    { name: '马爱国', src: '08pic.jpg', sex: 'female', des: '喜欢猫'},
    { name: '邓小茜', src: '04pic.jpg', sex: 'male', des: '喜欢运动'},
    { name: '马学习', src: '06pic.jpg', sex: 'female', des: '喜欢看书'}
]

主要html结构:

<body>
    <p class="wrapper">
        <p class="search">
            <input type="text" placeholder="请输入用户名" id="input">
            <ul id="searchUl">
                <li class="active" sex = "all">All</li>
                <li sex = "male">Male</li>
                <li sex = "female">Female</li>
            </ul>
        </p>
        <p class="userList">
            <ul id="list">
                <!-- 方便确定插入数据的结构和样式 -->
                <!-- <li><img src="./images/01pic.jpg" alt="">
                    <span class="name">小航</span>
                    <span class="des">描述</span>
                </li> -->
            </ul>
        </p>
    </p>

    <script src="./searchingData.js"></script>
</body>

思路及js核心代码:

1)渲染dom结构:使用forEach()方法遍历数组,找出符合条件的数据,有几条数据就生成几个li结构代码块,然后把生成的li结构插入ul中去;

var listUl = document.getElementById('list');
var oInp = document.getElementById('input');
var sUl = document.getElementById('searchUl');


//渲染dom结构,遍历数组使用forEach()方法
function render(list){
    var str = '';
    list.forEach(function(ele, index){
        str += '<li><img src="./images/'+ ele.src +'" alt="">\
        <span class="name">'+ ele.name +'</span>\
        <span class="des">'+ ele.des +'</span></li>';
    });
    listUl.innerHTML = str;
}

2)单一输入框文字筛选:获取input输入框输入的值,绑定一个oninput事件,使用使用数组过滤筛选方法filter()进行文本过滤;

//获取input输入的value值,需绑定一个oninput事件,获取过滤结果后渲染
oInp.oninput = function(){
    var text = this.value; 
    //state.text = this.value; //组合条件筛选
    render(filterText(text, person)); //单一筛选、渲染
    //render(addFn(filterFn,person)); //组合条件筛选、渲染
}

//输入文本过滤
function filterText(val, arr){
    var fArr = arr.filter(function(ele, index){
        if(ele.name.indexOf(val) !== -1){
            return true;
        }
    })
    return fArr;
}

3)单一点击按钮筛选:点击事件绑定在ul上,由li触发

//绑定点击事件
sUl.addEventListener('click', function(e){
    if(e.target.tagName == 'LI'){
        var sex = e.target.getAttribute('sex');
        //state.sex = e.target.getAttribute('sex'); //组合条件筛选
        document.getElementsByClassName('active')[0].className = ''; //修改点击按钮的样式
        e.target.className = 'active'; //修改点击按钮的样式
        render(filterSex(sex, person));
        //render(addFn(filterFn,person));//组合条件筛选、渲染
    }
})

//点击按钮筛选
function filterSex(sex, arr){
    if(sex == 'all'){
        return arr;
    }else{
        var sArr = arr.filter(function(ele, index){
            if(sex == ele.sex){
                return true;
            }
        })
        return sArr;
    }
}

4)组合条件筛选:通过两个对象的prop把组合对象(输入框和按钮)和筛选函数联系起来

//组合筛选,在一个筛选结果的基础上筛选(修改传入数组arr),参数lastArr上一次筛选返回的数组

//筛选条件:实现筛选条件的函数
var filterFn = {
    text: filterText,
    sex: filterSex
}

//筛选条件:之前的筛选的值text、sex 要改为 state.text state.sex
var state = {
    text: '',
    sex: 'all'
}

//组合
function addFn(obj, arr){
    var lastArr = arr;
    for(var prop in obj){
        lastArr = obj[prop](state[prop], lastArr);
        console.log(lastArr);
    }
    return lastArr;
}

相关文章:

JavaScript前端数据多条件筛选功能实现代码

JavaScript实现前端数据多条件筛选功能的实例

相关视频:

使用JavaScript-李炎恢Javascript视频教程

以上就是案例详解_使用javascript编写用户列表组合条件筛选的详细内容,更多请关注其它相关文章!