设为首页 加入收藏

TOP

每天一个JS 小demo之商品筛选。主要知识点:DOM方法综合运用
2017-10-13 10:49:46 】 浏览:4929
Tags:每天 一个 demo 商品 筛选 主要 知识点 DOM 方法 综合 运用

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style type="text/css">
nav {
height: 50px;
}
nav span {
margin: 0 5px;
}
.show {
color: red;
}
</style>
</head>
<body>
<nav></nav>
<ul>
<li>
<strong>手机:</strong>
<a href="java script:;">锤子T1</a>
<a href="java script:;">锤子T2</a>
<a href="java script:;">坚果U1</a>
<a href="java script:;">锤子M1</a>
<a href="java script:;">坚果Pro</a>
</li>
<li>
<strong>价格:</strong>
<a href="java script:;">3200</a>
<a href="java script:;">2600</a>
<a href="java script:;">899</a>
<a href="java script:;">2799</a>
<a href="java script:;">2299</a>
</li>
<li>
<strong>屏幕:</strong>
<a href="java script:;">399</a>
<a href="java script:;">600</a>
<a href="java script:;">800</a>
<a href="java script:;">1200</a>
</li>
</ul>
<script type="text/java script">
(function(){
var nav = document.querySelector('nav');
var li = document.querySelectorAll('li');
var ids = [];
for(var i = 0; i <li.length; i++){
setClick(li[i],i);
}
function setClick(parent,index){
var option = parent.getElementsByTagName("a");
for(var i = 0; i < option.length; i++){
/*
建一个数组
*/
option[i].onclick = function(){
for(var i = 0; i < option.length; i++){
option[i].className = "";
}
this.className = "show";
var span = ids[index];
if(ids[index]){
span.children[0].innerHTML = this.innerHTML;
return;
}
span = document.createElement("span");
var a = document.createElement("a");
var strong = document.createElement("strong");
a.innerHTML = "x";
a.href="java script:;";
a.onclick = function(){
nav.removeChild(span);
ids[index]="";
/*
删除元素清空数组对象位
*/
for(var i = 0; i < option.length; i++){
option[i].className = "";
}
}
strong.innerHTML = this.innerHTML;
span.appendChild(strong);
span.appendChild(a);
ids[index] = span;
/*
元素生成之后,先存入数组的对应位
*/

/*
按照数组的顺序重新添加一遍元素
*/
for(var i = 0; i < ids.length; i++){
if(ids[i]){
nav.appendChild(ids[i]);
}
}
};
}
}
})();
</script>
</body>
</html>

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇前后端分离思考 下一篇javascript运动框架(二)

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目