蝙蝠岛资源网 Design By www.hbtsch.com
本文实例为大家分享了js实现查询商品的具体代码,供大家参考,具体内容如下
<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-prro">查询</button>
</div>
<table>
<thead>
<tr>
<th>id</th>
<th>产品名称</th>
<th>价格</th>
</tr>
</thead>
<tbody>
<!-- <tr>
<td>1</td>
<td>小米</td>
<td>2000</td>
</tr>
<tr>
<td>2</td>
<td>oppo</td>
<td>999</td>
</tr>
<tr>
<td>3</td>
<td>荣耀</td>
<td>1299</td>
</tr>
<tr>
<td>4</td>
<td>华为</td>
<td>1999</td>
</tr> -->
</tbody>
</table>
css:
*{
margin: 0;
padding: 0;
}
body{
width: 1000px;
margin: 0 auto;
}
.search{
text-align: center;
/* margin: 0 auto; */
}
table{
padding-top: 20px;
width: 1000px;
height: 100px;
/* border: 1px solid #ccc; */
margin:0 auto ;
}
th,tr,td{
border: 1px solid #ccc;
text-align: center;
height: 50px;
}
js:
<script>
//利用数组的方式对数据进行存储
var data = [{
id:1,
pname: '小米',
price :3999
},{
id:2,
pname: 'oppo',
price :999
},
{
id:3,
pname: '荣耀',
price :1299
},
{
id:4,
pname: '华为',
price :1999
}
];
//1.获取相应的元素
var tbody = document.querySelector('tbody');
//2.把数据渲染到页面中
//forEach()。属于数组中的方法,第一个参数表示为每个元素,第二个参数为每个元素的索引值,第三个参数为整体元素的表达式
//为了方便使用渲染函数,需要先调用一次,将商品渲染
setDate(data);
//应为筛选后也要进行渲染,此时可以将此步设置为封装函数
function setDate(mydata){
//重新渲染数据的时候,先清空tbody原来的数据
tbody.innerHTML = '';
mydata.forEach(function(value){
//测试
// console.log(value);
//将每个对象放进tbody中去,需要先给tbody创建行 tr
var tr = document.createElement('tr');
//已知每个对想的属性名为value,因此可以利用获取对象中值的方式进行赋值 例如:value.id
tr.innerHTML = '<td>'+value.id +'</td> <td>'+value.pname +'</td> <td>'+value.price +'</td>';
tbody.appendChild(tr);
});
}
//3.利用判断查询商品信息
//filter()方法可以用到判断的效果
//首先获取相应的元素信息
var search_price = document.querySelector('.search-price');
var start = document.querySelector('.start');
var end = document.querySelector('.end');
search_price.addEventListener('click',function(){
// alert(1) //测试
//定义一个变量名进行数据接受
var newDate = data.filter(function(value){
// console.log(value);
//返回值: 起始价 <= 价格 <= 最终价
return value.price >= start.value && value.price <= end.value;
});
// 打印变量名
// console.log(newDate);//测试
//将筛选完之后的对象渲染到页面中去
//调用渲染函数
setDate(newDate);
})
//4.通过商品名称查询,此处的查询可以利用filter()方法进行书写,也可以利用以下方式书写查找
//通过some进行查询,因为some方法查到后直接退出,比较有效率,同时some返回的值为布尔值
//首先获取相关元素
var product = document.querySelector('.product');//输入
var search_pro = document.querySelector('.search-prro'); //查询
search_pro.addEventListener('click',function(){
//创建一个新的数组用来获取
var arr = [];
data.some(function(value){
if(value.pname === product.value){
// console.log(value); //测试
arr.push(value);//只要是满足条件,就将获取到的元素添加到新数组中去
return true; //return 必须为true
}
});
// 在此调用渲染函数
setDate(arr); //此时的 value.price 中的value形参传递的是arr实参对象
})
</script>
实现效果:
为什么最后需要利用some进行查询:
因为利用数组的some方法,查询遍历,只要返回值结果为true便可结束程序,不需要浪费太多的事件,大大加强了办事效率
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
js,查询商品
蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com
暂无js实现查询商品案例的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年11月08日
2025年11月08日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]


