多个输入框联合搜索

如果你有多个输入框,并希望进行联合精准搜索,可以通过组合多个输入框的值来过滤数据。在JavaScript中,常见的做法是先收集每个输入框的值,然后使用这些值过滤数据。

示例:多个输入框联合精准搜索

假设有多个输入框用于过滤不同的属性(例如姓名、年龄和城市),你可以使用下面的代码来实现联合精准搜索:

html 复制代码
<input type="text" id="nameSearch" placeholder="Search by name">
<input type="number" id="ageSearch" placeholder="Search by age">
<input type="text" id="citySearch" placeholder="Search by city">

<button onclick="searchData()">Search</button>

<ul id="results"></ul>

<script>
const data = [
    { id: 1, name: 'John', age: 30, city: 'New York' },
    { id: 2, name: 'Jane', age: 25, city: 'Los Angeles' },
    { id: 3, name: 'Mike', age: 35, city: 'Chicago' },
    { id: 4, name: 'Sara', age: 28, city: 'San Francisco' },
];

function searchData() {
    const nameTerm = document.getElementById('nameSearch').value.toLowerCase();
    const ageTerm = document.getElementById('ageSearch').value;
    const cityTerm = document.getElementById('citySearch').value.toLowerCase();

    // 联合过滤
    const filteredData = data.filter(item => {
        return (!nameTerm || item.name.toLowerCase().includes(nameTerm)) &&
               (!ageTerm || item.age == ageTerm) &&
               (!cityTerm || item.city.toLowerCase().includes(cityTerm));
    });

    displayResults(filteredData);
}

function displayResults(results) {
    const resultsContainer = document.getElementById('results');
    resultsContainer.innerHTML = '';

    results.forEach(item => {
        const li = document.createElement('li');
        li.textContent = `${item.name}, ${item.age}, ${item.city}`;
        resultsContainer.appendChild(li);
    });
}
</script>
相关推荐
L耀早睡7 分钟前
mapreduce打包运行
大数据·前端·spark·mapreduce
咖啡の猫8 分钟前
JavaScript基础-创建对象的三种方式
开发语言·javascript·ecmascript
MaCa .BaKa19 分钟前
38-日语学习小程序
java·vue.js·spring boot·学习·mysql·小程序·maven
HouGISer20 分钟前
副业小程序YUERGS,从开发到变现
前端·小程序
outstanding木槿26 分钟前
react中安装依赖时的问题 【集合】
前端·javascript·react.js·node.js
小吕学编程1 小时前
Jackson使用详解
java·javascript·数据库·json
霸王蟹1 小时前
React中useState中更新是同步的还是异步的?
前端·javascript·笔记·学习·react.js·前端框架
霸王蟹1 小时前
React Hooks 必须在组件最顶层调用的原因解析
前端·javascript·笔记·学习·react.js
专注VB编程开发20年1 小时前
asp.net IHttpHandler 对分块传输编码的支持,IIs web服务器后端技术
服务器·前端·asp.net
爱分享的程序员2 小时前
全栈项目搭建指南:Nuxt.js + Node.js + MongoDB
前端