js實現(xiàn)查詢商品案例
更新時間:2020年07月22日 09:35:17 作者:黑白兩客
這篇文章主要為大家詳細介紹了js實現(xiàn)查詢商品案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了js實現(xiàn)查詢商品的具體代碼,供大家參考,具體內(nèi)容如下
<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>產(chǎn)品名稱</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> //利用數(shù)組的方式對數(shù)據(jù)進行存儲 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.把數(shù)據(jù)渲染到頁面中 //forEach()。屬于數(shù)組中的方法,第一個參數(shù)表示為每個元素,第二個參數(shù)為每個元素的索引值,第三個參數(shù)為整體元素的表達式 //為了方便使用渲染函數(shù),需要先調(diào)用一次,將商品渲染 setDate(data); //應為篩選后也要進行渲染,此時可以將此步設置為封裝函數(shù) function setDate(mydata){ //重新渲染數(shù)據(jù)的時候,先清空tbody原來的數(shù)據(jù) tbody.innerHTML = ''; mydata.forEach(function(value){ //測試 // console.log(value); //將每個對象放進tbody中去,需要先給tbody創(chuàng)建行 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) //測試 //定義一個變量名進行數(shù)據(jù)接受 var newDate = data.filter(function(value){ // console.log(value); //返回值: 起始價 <= 價格 <= 最終價 return value.price >= start.value && value.price <= end.value; }); // 打印變量名 // console.log(newDate);//測試 //將篩選完之后的對象渲染到頁面中去 //調(diào)用渲染函數(shù) setDate(newDate); }) //4.通過商品名稱查詢,此處的查詢可以利用filter()方法進行書寫,也可以利用以下方式書寫查找 //通過some進行查詢,因為some方法查到后直接退出,比較有效率,同時some返回的值為布爾值 //首先獲取相關元素 var product = document.querySelector('.product');//輸入 var search_pro = document.querySelector('.search-prro'); //查詢 search_pro.addEventListener('click',function(){ //創(chuàng)建一個新的數(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); //此時的 value.price 中的value形參傳遞的是arr實參對象 }) </script>
實現(xiàn)效果:
為什么最后需要利用some進行查詢:
因為利用數(shù)組的some方法,查詢遍歷,只要返回值結果為true便可結束程序,不需要浪費太多的事件,大大加強了辦事效率
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
相關文章
jsp網(wǎng)頁搜索結果中實現(xiàn)選中一行使其高亮
在做搜索結果時為了好看需要將選中的行變的高亮些,下面有個不錯的示例,需要的朋友可以參考下2014-02-02JavaScript實現(xiàn)手機號碼 3-4-4格式并控制新增和刪除時光標的位置
這篇文章主要介紹了JavaScript實現(xiàn)手機號碼 3-4-4格式并控制新增和刪除時光標的位置,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06如何讓一個層關閉之后,就算刷新頁面了也不顯示。除非關閉頁面再次打開
這個功能,一般可用于廣告的顯示,當關閉后,就不顯示,除非重新關閉打開,增加用戶體驗2008-09-09利用 Chrome Dev Tools 進行頁面性能分析的步驟說明(前端性能優(yōu)化)
這篇文章主要介紹了利用 Chrome Dev Tools 進行頁面性能分析的步驟說明(前端性能優(yōu)化),本文給大家介紹的非常想詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02