JS实现购物车
2021-04-26 17:26
YPE html>
标签:获取 return 元素属性 price str 总数 ice compare function
JS实现购物车
1.实现思路:
(1)在body中定义一个id="list",将所有商品存放在一个列表中,当进入购物车时如果有两个商品被勾选了,需要计算出总共的价钱和商品的件数以及最贵的商品价格;
(2)在JS中获取元素属性,分别把它们存放在数组中;
(3)点击加号进行商品添加,点击减号进行商品移除;
(4)将上一步用两个点击函数来实现添加和移除;
(5)在JS中用for循环来计算总价钱和比较最贵的商品;
2.代码思路
1.商品列表:
-
0
单价:10元
总计:0元
-
0
单价:5元
总计:0元
-
0
单价:6元
总计:0元
-
0
单价:8元
总计:0元
2.商品的添加与移除:
//商品的添加与移除
function tab(a){
var oInput = aLi[a].getElementsByTagName("input")
var oStrong = aLi[a].getElementsByTagName("strong")[0]
var oEm = aLi[a].getElementsByTagName("em")[0]
var oSpan = aLi[a].getElementsByTagName("span")[0]
var num = 0
oInput[1].onclick = function(){
num++
oStrong.innerHTML = num
var oPrice = parseFloat(oEm.innerHTML)
oSpan.innerHTML = parseFloat(num)*oPrice+"元"
var addShop = count()
// console.log(addShop)
oP[0].innerHTML = "商品数量总计:"+addShop+"件"
var all = all_price()
oP[1].innerHTML = "共消费:"+all+"元"
var max = compare()
// console.log(max)
oP[2].innerHTML = "商品最贵的是:"+max+"元"
}
oInput[0].onclick = function(){
num--
if(num
num = 0
}
oStrong.innerHTML = num
var oPrice = parseFloat(oEm.innerHTML)
oSpan.innerHTML = parseFloat(num)*oPrice+"元"
var addShop = count()
// console.log(addShop)
oP[0].innerHTML = "商品数量总计:"+addShop+"件"
var all = all_price()
oP[1].innerHTML = "共消费:"+all+"元"
}
}
3.计算总价值:
//消费总计
function all_price(){
var sum = 0
for (var i=0;i sum+=parseFloat(oSpan[i].innerHTML) } // console.log(sum) return sum } 4.商品总数量: //商品数量求和 function count(){ var sum = 0 for (var i=0;i sum+=parseFloat(oStrong[i].innerHTML) } // console.log(sum) return sum } 5.最贵商品价格: //比较最大值 function compare(){ var arr = [] for (var i=0;i arr.push(parseFloat(oSpan[i].innerHTML)) } arr.sort(function(a,b){ return b-a }) return arr[0] } 3.实现代码
em{ font-style: normal; } ul li{ list-style: none; }
-
0
单价:10元
总计:0元
-
0
单价:5元
总计:0元
-
0
单价:6元
总计:0元
-
0
单价:8元
总计:0元
商品数量总计:0件
共消费:0元
商品最贵的是:0元
var oList = document.getElementById("list")
var aLi = oList.getElementsByTagName("li")
var oStrong = oList.getElementsByTagName("strong")
var oP = document.getElementsByTagName("p")
var oSpan = document.getElementsByTagName("span")
for (var i=0;i tab(i) } //商品的添加与移除 function tab(a){ var oInput = aLi[a].getElementsByTagName("input") var oStrong = aLi[a].getElementsByTagName("strong")[0] var oEm = aLi[a].getElementsByTagName("em")[0] var oSpan = aLi[a].getElementsByTagName("span")[0] var num = 0 oInput[1].onclick = function(){ num++ oStrong.innerHTML = num var oPrice = parseFloat(oEm.innerHTML) oSpan.innerHTML = parseFloat(num)*oPrice+"元" var addShop = count() // console.log(addShop) oP[0].innerHTML = "商品数量总计:"+addShop+"件" var all = all_price() oP[1].innerHTML = "共消费:"+all+"元" var max = compare() // console.log(max) oP[2].innerHTML = "商品最贵的是:"+max+"元" } oInput[0].onclick = function(){ num-- if(num
num = 0 } oStrong.innerHTML = num var oPrice = parseFloat(oEm.innerHTML) oSpan.innerHTML = parseFloat(num)*oPrice+"元" var addShop = count() // console.log(addShop) oP[0].innerHTML = "商品数量总计:"+addShop+"件" var all = all_price() oP[1].innerHTML = "共消费:"+all+"元" } } //商品数量求和 function count(){ var sum = 0 for (var i=0;i sum+=parseFloat(oStrong[i].innerHTML) } // console.log(sum) return sum } //消费总计 function all_price(){ var sum = 0 for (var i=0;i sum+=parseFloat(oSpan[i].innerHTML) } // console.log(sum) return sum } //比较最大值 function compare(){ var arr = [] for (var i=0;i arr.push(parseFloat(oSpan[i].innerHTML)) } arr.sort(function(a,b){ return b-a }) return arr[0] } JS实现购物车 标签:获取 return 元素属性 price str 总数 ice compare function 原文地址:https://www.cnblogs.com/tongguilin/p/12219584.html
下一篇:Webpack快速入门