js實(shí)現(xiàn)查詢商品案例
本文實(shí)例為大家分享了js實(shí)現(xiàn)查詢商品的具體代碼,供大家參考,具體內(nèi)容如下
<div class="search"> 按照價(jià)格查詢:<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>產(chǎn)品名稱</th> <th>價(jià)格</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> //利用數(shù)組的方式對數(shù)據(jù)進(jìn)行存儲 var data = [{ id:1, pname: '小米', price :3999 },{ id:2, pname: 'oppo', price :999 }, { id:3, pname: '榮耀', price :1299 }, { id:4, pname: '華為', price :1999 } ]; //1.獲取相應(yīng)的元素 var tbody = document.querySelector('tbody'); //2.把數(shù)據(jù)渲染到頁面中 //forEach()。屬于數(shù)組中的方法,第一個(gè)參數(shù)表示為每個(gè)元素,第二個(gè)參數(shù)為每個(gè)元素的索引值,第三個(gè)參數(shù)為整體元素的表達(dá)式 //為了方便使用渲染函數(shù),需要先調(diào)用一次,將商品渲染 setDate(data); //應(yīng)為篩選后也要進(jìn)行渲染,此時(shí)可以將此步設(shè)置為封裝函數(shù) function setDate(mydata){ //重新渲染數(shù)據(jù)的時(shí)候,先清空tbody原來的數(shù)據(jù) tbody.innerHTML = ''; mydata.forEach(function(value){ //測試 // console.log(value); //將每個(gè)對象放進(jìn)tbody中去,需要先給tbody創(chuàng)建行 tr var tr = document.createElement('tr'); //已知每個(gè)對想的屬性名為value,因此可以利用獲取對象中值的方式進(jìn)行賦值 例如:value.id tr.innerHTML = '<td>'+value.id +'</td> <td>'+value.pname +'</td> <td>'+value.price +'</td>'; tbody.appendChild(tr); }); } //3.利用判斷查詢商品信息 //filter()方法可以用到判斷的效果 //首先獲取相應(yīng)的元素信息 var search_price = document.querySelector('.search-price'); var start = document.querySelector('.start'); var end = document.querySelector('.end'); search_price.addEventListener('click',function(){ // alert(1) //測試 //定義一個(gè)變量名進(jìn)行數(shù)據(jù)接受 var newDate = data.filter(function(value){ // console.log(value); //返回值: 起始價(jià) <= 價(jià)格 <= 最終價(jià) return value.price >= start.value && value.price <= end.value; }); // 打印變量名 // console.log(newDate);//測試 //將篩選完之后的對象渲染到頁面中去 //調(diào)用渲染函數(shù) setDate(newDate); }) //4.通過商品名稱查詢,此處的查詢可以利用filter()方法進(jìn)行書寫,也可以利用以下方式書寫查找 //通過some進(jìn)行查詢,因?yàn)閟ome方法查到后直接退出,比較有效率,同時(shí)some返回的值為布爾值 //首先獲取相關(guān)元素 var product = document.querySelector('.product');//輸入 var search_pro = document.querySelector('.search-prro'); //查詢 search_pro.addEventListener('click',function(){ //創(chuàng)建一個(gè)新的數(shù)組用來獲取 var arr = []; data.some(function(value){ if(value.pname === product.value){ // console.log(value); //測試 arr.push(value);//只要是滿足條件,就將獲取到的元素添加到新數(shù)組中去 return true; //return 必須為true } }); // 在此調(diào)用渲染函數(shù) setDate(arr); //此時(shí)的 value.price 中的value形參傳遞的是arr實(shí)參對象 }) </script>
實(shí)現(xiàn)效果:
為什么最后需要利用some進(jìn)行查詢:
因?yàn)槔脭?shù)組的some方法,查詢遍歷,只要返回值結(jié)果為true便可結(jié)束程序,不需要浪費(fèi)太多的事件,大大加強(qiáng)了辦事效率
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jsp網(wǎng)頁搜索結(jié)果中實(shí)現(xiàn)選中一行使其高亮
在做搜索結(jié)果時(shí)為了好看需要將選中的行變的高亮些,下面有個(gè)不錯(cuò)的示例,需要的朋友可以參考下2014-02-02JavaScript實(shí)現(xiàn)手機(jī)號碼 3-4-4格式并控制新增和刪除時(shí)光標(biāo)的位置
這篇文章主要介紹了JavaScript實(shí)現(xiàn)手機(jī)號碼 3-4-4格式并控制新增和刪除時(shí)光標(biāo)的位置,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06如何讓一個(gè)層關(guān)閉之后,就算刷新頁面了也不顯示。除非關(guān)閉頁面再次打開
這個(gè)功能,一般可用于廣告的顯示,當(dāng)關(guān)閉后,就不顯示,除非重新關(guān)閉打開,增加用戶體驗(yàn)2008-09-09利用 Chrome Dev Tools 進(jìn)行頁面性能分析的步驟說明(前端性能優(yōu)化)
這篇文章主要介紹了利用 Chrome Dev Tools 進(jìn)行頁面性能分析的步驟說明(前端性能優(yōu)化),本文給大家介紹的非常想詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02JavaScript實(shí)現(xiàn)隨機(jī)點(diǎn)名小程序
這篇文章主要介紹了JavaScript實(shí)現(xiàn)隨機(jī)點(diǎn)名小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10JS正則表達(dá)式大全(整理詳細(xì)且實(shí)用)
JS正則表達(dá)式大全(整理詳細(xì)且實(shí)用)。需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11