多个输入框联合搜索

如果你有多个输入框,并希望进行联合精准搜索,可以通过组合多个输入框的值来过滤数据。在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>
相关推荐
boooooooom6 小时前
别再用错 ref/reactive!90%程序员踩过的响应式坑,一文根治
javascript·vue.js·面试
德育处主任6 小时前
『NAS』一句话生成网页,在NAS部署UPage
前端·javascript·aigc
前端老兵AI6 小时前
前端工程化实战:Vite + ESLint + Prettier + Husky 从零配置(2026最新版)
前端·vite
bluceli6 小时前
浏览器渲染原理与性能优化实战指南
前端·性能优化
张元清6 小时前
Astro 6.0:被 Cloudflare 收购两个月后,这个"静态框架"要重新定义全栈了
前端·javascript·面试
凉拌西红柿6 小时前
如何用工具定位性能瓶颈
前端
青青家的小灰灰6 小时前
深入理解 async/await:现代异步编程的终极解决方案
前端·javascript·面试
阿懂在掘金6 小时前
早点下班(Vue2.7版):旧项目也能少写 40%+ 异步代码
前端·vue.js·开源
Mintopia6 小时前
Web性能测试流程全解析:从概念到落地的完整指南
前端·性能优化·测试
用户5757303346246 小时前
JavaScript 原型继承全解析:从 call/apply 到寄生组合式继承
javascript