中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

原生js實現商品篩選功能

發布時間:2020-09-16 19:35:56 來源:腳本之家 閱讀:133 作者:冰雪為融 欄目:web開發

本文實例為大家分享了js商品篩選功能的具體代碼,供大家參考,具體內容如下

用到的知識:js基礎、dom、第一種方法用到的是js中的數組方法,第二種方法用到的是json和for-in以及es6

實現步驟

1、根據數據結構生成HTML結構(利用dom操作)

2、獲取每一個li,給每一個li中每一個a標簽綁定事件處理函數

3、點擊a標簽,把a標簽的內容添加在對象中,同時添加樣式

4、根據對象存的屬性生成選擇則條件的HTML結構(按順序排列)

5、點擊關閉選擇的條件,刪除數據,移除HTML結構,去除在其對應的li中的樣式

第一種方法

<script>
 window.onload = function(){
 var oType = document.getElementById('type');
 var oChoose = document.getElementById('choose');
 var oChosDiv = oChoose.getElementsByTagName('div')[0];
 var crumbData = [
  {
  "title": "品牌",
  "data": [ "蘋果","小米","錘子","魅族","華為","三星","OPPO","vivo","樂視"]
  },
  {
  "title": "尺寸",
  "data": ["4.0-4.5英寸","4.6-4.9英寸","5.0-5.5英寸","6.0英寸以上"]
  },
  {
  "title": "系統",
  "data": ["android","ios","window phone","無","其他"]
  },
  {
  "title": "網絡",
  "data": ["聯通3G","雙卡單4G","雙卡雙4G","聯通4G"]
  }
 ]
 //利用dom動態添加元素
 for(var i=0; i<crumbData.length; i++){
  var aLi = document.createElement('li');
  var aSpan = document.createElement('span');
  
  aSpan.innerHTML = crumbData[i].title;
  aLi.appendChild(aSpan);
  for(var j = 0; j<crumbData[i].data.length; j++){
  var aA = document.createElement('a');
  aA.innerHTML = crumbData[i].data[j];
  aLi.appendChild(aA); 
  }
  oType.appendChild(aLi);
  }
  
 var aLi = oType.getElementsByTagName('li');
 var arr = [];//用來存放篩選條件
 for(var i = 0; i<aLi.length; i++){
  arr.push(0);
  }//先將數組中存放aLi.length個0,方便接下來按li的順序存放數據
 for(var i=0; i<aLi.length; i++){
  
  aLi[i].prevNode = null;//記錄點擊的a標簽
  aLi[i].index = i;//記錄每一個li的下標
  var aA = aLi[i].getElementsByTagName('a');
  
  for(var j=0; j<aA.length; j++){  
  aA[j].onclick = function(){
   
   var parent = this.parentNode;//點擊的a標簽的父級li
   //既要生成選擇的結構,還要對選擇的結構進行排序
   //點擊同一行篩選條件,只能有一個
   if(parent.prevNode){
   parent.prevNode.style.color = ''; 
   }
   this.style.color = 'red';
   arr[parent.index] = this.innerText;
  oChosDiv.innerHTML = ''; 
  for(var i=0; i<arr.length; i++){
   if(arr[i]){ //只有當arr[i]的值不為0時,也即與下標對應的第i個li中有被選中的時候才執行下面的代碼  
  var oChomark = document.createElement('mark');
   
  oChomark.innerHTML = arr[i];
  var oCxa = document.createElement('a'); 
  oCxa.innerHTML = 'X';
  oCxa.setAttribute('name',i);//標記商品篩選區的a所在的li是第幾個
  oChomark.appendChild(oCxa); 
  oChosDiv.appendChild(oChomark);}
  }
  var num = 0;
  var ChoseA = oChosDiv.getElementsByTagName('a');
  for(var i = 0; i<ChoseA.length; i++){
   ChoseA[i].index = i;
   ChoseA[i].onclick = function(){
   num = parseInt(this.getAttribute('name'));//得到刪除a標簽在第幾個li中(記得將字符串格式轉化為數字格式)
   this.parentNode.remove();
   aLi[num].prevNode.style.color = '';
   arr[num]=0;//讓刪除的元素在數組中對應下標的值變為0
   }
   }
  
   parent.prevNode = this;
   
   }
  }
  }
 }

</script>

第二種方法

 // 篩選條件
 var filterChoose = ["name","size","system","www"];
 var filterObj = {}
 
 for( var k = 0; k< lis.length; k++ ){
 //得到每一個li中的所有的a標簽
 itemA = lis[k].querySelectorAll("a");
 lis[k].prevNode = null; // 記錄點擊的a標簽
 lis[k].index = k; // 記錄每一個li的下標
 for( var m = 0; m < itemA.length; m++ ){
  // 給每一個a標簽綁定點擊處理函數
  itemA[m].onclick = function(){
  var parent = this.parentNode; // 點擊的a標簽的父級 li
  // 既要生成選擇的結構,還要對選擇的結構進行排序
  // 點擊同一行篩選條件,只能有一個
  /*
   {
   key: 
   key2: 
   }
   key值是唯一的
   key值改怎定義???
  */
  // 把每一個li的下標作為key值,把點擊的a的內容作為值
  chooseObj[parent.index] = this.innerText;
  console.log(chooseObj)
  // 生成篩選條件的結構
  createChooseHtml();
  // 存一下篩選的值
  filterObj[filterChoose[parent.index]] = this.innerText.trim();
  // 篩選出想要的數據
  filterHandle()
  // 去掉之前點擊的a標簽的color
  if(parent.prevNode){
   parent.prevNode.style.color = ''
  }
  this.style.color = 'red';
  parent.prevNode = this; // 點擊之后記錄點擊的這個元素
  }
 }
 }
 // 選擇的容器
 var chooseElement = document.querySelector("#choose div")
 function createChooseHtml(){
 // 對象是沒有順序
 /*
  chooseObj = {
  1: "4.0",
  0:"蘋果",
  3:
  2:
  }
 */
 var html = '';
 for( var i = 0; i < lis.length; i++ ){
  // i: 0 1 2 3
  if( chooseObj[i] ){
  // html += '<mark>'+chooseObj[i]+'<a href="javascript:;" rel="external nofollow" rel="external nofollow" >x</a></mark>'
  // 生成結構的時候在行間保存對象的key值
  html += `<mark>${chooseObj[i]}<a data-index="${i}" href="javascript:;" rel="external nofollow" rel="external nofollow" >x</a></mark>`
  }
 }
 
 chooseElement.innerHTML = html;
 
 
 // 獲取到所有的元素
 var chooseA = chooseElement.querySelectorAll("a");
 
 for(var j = 0; j < chooseA.length; j++){
  chooseA[j].onclick = function (){
  // 移出當前點擊a標簽的父級
  // this.parentNode.parentNode.removeChild(this.parentNode);
  this.parentNode.remove();
  // 刪數據
  delete chooseObj[this.dataset.index];
  // 點擊每一個li中的a標簽存的屬性
  lis[this.dataset.index].prevNode.style.color = '';
  console.log(chooseObj)
  };
 }
 
 }
 var shopList = document.querySelector(".shop-list")
 //篩選數據
 function filterHandle(){
 var filterArr = shopsList; // 等于原始數組
 for(var attr in filterObj){
  // 做一個過濾
  filterArr = filterArr.filter(function(obj){
  console.log(attr)
  return obj[attr] === filterObj[attr]
  })
 }
 shopList.innerHTML = '<pre>'+JSON.stringify(filterArr,null,3)+'</pre>';
 }
 
 
 </script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

荔波县| 上思县| 慈溪市| 永平县| 曲阜市| 达孜县| 德安县| 墨脱县| 卓资县| 邵阳县| 墨江| 尼木县| 揭阳市| 逊克县| 清新县| 云林县| 江城| 乌鲁木齐县| 监利县| 衡阳县| 丹江口市| 扶沟县| 蒙山县| 吉林市| 台安县| 绥化市| 囊谦县| 普安县| 兴国县| 勐海县| 九龙县| 左权县| 北流市| 辽源市| 肥城市| 南充市| 乌拉特后旗| 巴林左旗| 德阳市| 海原县| 河间市|