首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >用原生js实现商品表单筛选查询功能

用原生js实现商品表单筛选查询功能

作者头像
程序媛夏天
发布2024-01-18 21:25:25
发布2024-01-18 21:25:25
96900
代码可运行
举报
运行总次数:0
代码可运行
需求分析

1.能够根据价格搜索出对应的商品; 2.能够根据商品名称查询出对应商品;

实现效果

1.

2.

源代码
代码语言:javascript
代码运行次数:0
运行
复制
<style>
  .search{
    margin: 0 auto;
    margin-bottom:10px;
  }
  input{
    width: 50px;
  }
  table,table tr th, table tr td { border:1px solid #000; }
  table { width: 500px; min-height: 25px; line-height: 25px; text-align: center; border-collapse: collapse; padding:2px;}   
</style>
代码语言:javascript
代码运行次数:0
运行
复制
<body>
  <div class="search">
    按照价格查询:<input type="text" class="start">- <input type="text" class="end">
    <button class="search-price">搜索</button>按照商品名称查询:
    <input type="text" class="product">
    <button class="search-name">查询</button>
  </div>
  <table>
    <thead>
      <tr>
        <th>id</th>
        <th>产品名称</th>
        <th>价格</th>
      </tr>
    </thead>
    <tbody>
    </tbody>
  </table>
代码语言:javascript
代码运行次数:0
运行
复制
<script>
   var data = [{
    id:1,
    pname:'小米',
    price:1000
   },
   {
    id:2,
    pname:'华为',
    price:2000
   },
   {
    id:3,
    pname:'荣耀',
    price:3999
   },
   {
    id:4,
    pname:'诺基亚',
    price:7000
   }];
   //1.先获取相应是元素
   var tbody = document.querySelector('tbody');
   var search_price = document.querySelector('.search-price');
   var start = document.querySelector('.start');
   var end = document.querySelector('.end');
   var search_name = document.querySelector('.search-name');
   var product = document.querySelector('.product');
   setDate(data);
   //2.把数据渲染到页面中
   function setDate(mydata){
       tbody.innerHTML = '';
       mydata.forEach(function(value){
        var tr = document.createElement('tr');
        tr.innerHTML = '<td>'+value.id+'</td><td>'+value.pname+'</td><td>'+value.price+'</td>';
        tbody.appendChild(tr);
      });
   }
  
   //3.根据价格查询商品
   //当我们点击了按钮,就可以根据我们的商品价格去筛选数组里面的对象
   //搜索按钮
   search_price.addEventListener('click',function(){
      var newGoods = data.filter(function(value){
        return value.price >= start.value && value.price <= end.value;
      })
      console.log(newGoods);
      setDate(newGoods)
   });
   //4.根据商品名称查询商品
   //如果查询数组中唯一的元素,用some方法更合适,因为找到这个元素,就不在进行循环,效率更高
   search_name.addEventListener('click',function(){
     var arr = [];
     data.some(function(value){
      if(value.pname === product.value){
        console.log("2",value);
        arr.push(value);
        return true;//用some()后面只能写true和false
      }
     });
     //把拿到的数据渲染到页面中
     setDate(arr)
   })
  </script>
主要用到的方法

forEach()、filter()和some()方法

注意: 如果查询数组中唯一的元素,用some方法更合适,因为找到这个元素,就不在进行循环,效率更高。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 需求分析
  • 实现效果
  • 源代码
  • 主要用到的方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档