原生js實(shí)現(xiàn)商品篩選功能
本文實(shí)例為大家分享了js商品篩選功能的具體代碼,供大家參考,具體內(nèi)容如下
用到的知識(shí):js基礎(chǔ)、dom、第一種方法用到的是js中的數(shù)組方法,第二種方法用到的是json和for-in以及es6
實(shí)現(xiàn)步驟
1、根據(jù)數(shù)據(jù)結(jié)構(gòu)生成HTML結(jié)構(gòu)(利用dom操作)
2、獲取每一個(gè)li,給每一個(gè)li中每一個(gè)a標(biāo)簽綁定事件處理函數(shù)
3、點(diǎn)擊a標(biāo)簽,把a(bǔ)標(biāo)簽的內(nèi)容添加在對(duì)象中,同時(shí)添加樣式
4、根據(jù)對(duì)象存的屬性生成選擇則條件的HTML結(jié)構(gòu)(按順序排列)
5、點(diǎn)擊關(guān)閉選擇的條件,刪除數(shù)據(jù),移除HTML結(jié)構(gòu),去除在其對(duì)應(yīng)的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","樂(lè)視"]
},
{
"title": "尺寸",
"data": ["4.0-4.5英寸","4.6-4.9英寸","5.0-5.5英寸","6.0英寸以上"]
},
{
"title": "系統(tǒng)",
"data": ["android","ios","window phone","無(wú)","其他"]
},
{
"title": "網(wǎng)絡(luò)",
"data": ["聯(lián)通3G","雙卡單4G","雙卡雙4G","聯(lián)通4G"]
}
]
//利用dom動(dòng)態(tài)添加元素
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 = [];//用來(lái)存放篩選條件
for(var i = 0; i<aLi.length; i++){
arr.push(0);
}//先將數(shù)組中存放aLi.length個(gè)0,方便接下來(lái)按li的順序存放數(shù)據(jù)
for(var i=0; i<aLi.length; i++){
aLi[i].prevNode = null;//記錄點(diǎn)擊的a標(biāo)簽
aLi[i].index = i;//記錄每一個(gè)li的下標(biāo)
var aA = aLi[i].getElementsByTagName('a');
for(var j=0; j<aA.length; j++){
aA[j].onclick = function(){
var parent = this.parentNode;//點(diǎn)擊的a標(biāo)簽的父級(jí)li
//既要生成選擇的結(jié)構(gòu),還要對(duì)選擇的結(jié)構(gòu)進(jìn)行排序
//點(diǎn)擊同一行篩選條件,只能有一個(gè)
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]){ //只有當(dāng)arr[i]的值不為0時(shí),也即與下標(biāo)對(duì)應(yīng)的第i個(gè)li中有被選中的時(shí)候才執(zhí)行下面的代碼
var oChomark = document.createElement('mark');
oChomark.innerHTML = arr[i];
var oCxa = document.createElement('a');
oCxa.innerHTML = 'X';
oCxa.setAttribute('name',i);//標(biāo)記商品篩選區(qū)的a所在的li是第幾個(gè)
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標(biāo)簽在第幾個(gè)li中(記得將字符串格式轉(zhuǎn)化為數(shù)字格式)
this.parentNode.remove();
aLi[num].prevNode.style.color = '';
arr[num]=0;//讓刪除的元素在數(shù)組中對(duì)應(yīng)下標(biāo)的值變?yōu)?
}
}
parent.prevNode = this;
}
}
}
}
</script>
第二種方法
// 篩選條件
var filterChoose = ["name","size","system","www"];
var filterObj = {}
for( var k = 0; k< lis.length; k++ ){
//得到每一個(gè)li中的所有的a標(biāo)簽
itemA = lis[k].querySelectorAll("a");
lis[k].prevNode = null; // 記錄點(diǎn)擊的a標(biāo)簽
lis[k].index = k; // 記錄每一個(gè)li的下標(biāo)
for( var m = 0; m < itemA.length; m++ ){
// 給每一個(gè)a標(biāo)簽綁定點(diǎn)擊處理函數(shù)
itemA[m].onclick = function(){
var parent = this.parentNode; // 點(diǎn)擊的a標(biāo)簽的父級(jí) li
// 既要生成選擇的結(jié)構(gòu),還要對(duì)選擇的結(jié)構(gòu)進(jìn)行排序
// 點(diǎn)擊同一行篩選條件,只能有一個(gè)
/*
{
key:
key2:
}
key值是唯一的
key值改怎定義???
*/
// 把每一個(gè)li的下標(biāo)作為key值,把點(diǎn)擊的a的內(nèi)容作為值
chooseObj[parent.index] = this.innerText;
console.log(chooseObj)
// 生成篩選條件的結(jié)構(gòu)
createChooseHtml();
// 存一下篩選的值
filterObj[filterChoose[parent.index]] = this.innerText.trim();
// 篩選出想要的數(shù)據(jù)
filterHandle()
// 去掉之前點(diǎn)擊的a標(biāo)簽的color
if(parent.prevNode){
parent.prevNode.style.color = ''
}
this.style.color = 'red';
parent.prevNode = this; // 點(diǎn)擊之后記錄點(diǎn)擊的這個(gè)元素
}
}
}
// 選擇的容器
var chooseElement = document.querySelector("#choose div")
function createChooseHtml(){
// 對(duì)象是沒(méi)有順序
/*
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>'
// 生成結(jié)構(gòu)的時(shí)候在行間保存對(duì)象的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 (){
// 移出當(dāng)前點(diǎn)擊a標(biāo)簽的父級(jí)
// this.parentNode.parentNode.removeChild(this.parentNode);
this.parentNode.remove();
// 刪數(shù)據(jù)
delete chooseObj[this.dataset.index];
// 點(diǎn)擊每一個(gè)li中的a標(biāo)簽存的屬性
lis[this.dataset.index].prevNode.style.color = '';
console.log(chooseObj)
};
}
}
var shopList = document.querySelector(".shop-list")
//篩選數(shù)據(jù)
function filterHandle(){
var filterArr = shopsList; // 等于原始數(shù)組
for(var attr in filterObj){
// 做一個(gè)過(guò)濾
filterArr = filterArr.filter(function(obj){
console.log(attr)
return obj[attr] === filterObj[attr]
})
}
shopList.innerHTML = '<pre>'+JSON.stringify(filterArr,null,3)+'</pre>';
}
</script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
通過(guò)實(shí)例了解Render Props回調(diào)地獄解決方案
這篇文章主要介紹了通過(guò)實(shí)例了解Render Props回調(diào)地獄解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
微信小程序MoxB實(shí)現(xiàn)全局狀態(tài)管理流程詳解
這篇文章主要介紹了微信小程序使用MoxB實(shí)現(xiàn)全局狀態(tài)管理方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-11-11
利用uni-app和uView實(shí)現(xiàn)多圖上傳功能全過(guò)程
最近在使用uniapp開發(fā)的微信小程序中使用了圖片上傳功能,下面這篇文章主要給大家介紹了關(guān)于利用uni-app和uView實(shí)現(xiàn)多圖上傳功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
window.print()打印根據(jù)高度設(shè)置居中顯示和布局(縱向橫向)
本文主要介紹了window.print()打印根據(jù)高度設(shè)置居中顯示和布局(縱向橫向),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
JavaScript的設(shè)計(jì)模式經(jīng)典之代理模式
代理模式的定義是把對(duì)一個(gè)對(duì)象的訪問(wèn), 交給另一個(gè)代理對(duì)象來(lái)操作。接下來(lái)通過(guò)本文給大家介紹JavaScript的設(shè)計(jì)模式之代理模式,感興趣的朋友一起學(xué)習(xí)吧2016-02-02
完美實(shí)現(xiàn)js選項(xiàng)卡切換效果(一)
這篇文章主要為大家詳細(xì)介紹如何完美實(shí)現(xiàn)js選項(xiàng)卡切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
webpack 開發(fā)和生產(chǎn)并行設(shè)置的方法
這篇文章主要介紹了webpack 開發(fā)和生產(chǎn)并行設(shè)置的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11

