博主信息
博文 1
粉丝 0
评论 0
访问量 419
相关推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
购物车作业提交
手机用户0035810
原创
419人浏览过

购物车效果图:

代码如下:

  1. <script>
  2. function checkAll(){
  3. let status=document.querySelector('.check-all').checked;
  4. // console.log(status)
  5. let list=document.querySelectorAll('.list li input[type=checkbox]');
  6. // console.log(list)
  7. list.forEach(item=>item.checked=status)
  8. autoCalc()
  9. }
  10. function checkItems(){
  11. let list=document.querySelectorAll('.list li input[type=checkbox]');
  12. // console.log(list)
  13. let status=[...list].every(item=>item.checked)
  14. document.querySelector('.check-all').checked=status
  15. autoCalc()
  16. // checkStatus=[...list].map(arg1=>arg1.checked)
  17. // console.log(checkStatus)
  18. }
  19. // list=document.querySelectorAll('.list li input[type=checkbox]')
  20. //
  21. // let status=[...list][0].checked
  22. let nums=document.querySelectorAll('.num')
  23. // console.log(nums)
  24. function autoCalc(){
  25. //定义数量数组:
  26. let numArr= [...nums].map(num=> parseInt(num.value));
  27. console.log(numArr)
  28. console.log(numArr)
  29. // console.log(list)
  30. // console.log(numArr)
  31. //定义金额数组:
  32. let price=document.querySelectorAll('.price')
  33. // console.log(price)
  34. let priceArr=[...price].map(item=>parseInt(item.textContent))
  35. // console.log(priceArr)
  36. //在checkbox未选中的时候,在数据设置为0之前先计算单个商品总金额,:
  37. let amountArr1= numArr.map((item,index)=>item*priceArr[index])
  38. // console.log(amountArr)
  39. //在checkbox未选中的时候,把商品数量那个数组对应的值改为0
  40. let list=document.querySelectorAll('.list li input[type=checkbox]');
  41. checkStatus=[...list].map(arg1=>arg1.checked)
  42. checkStatus.map(function (arg1,index){
  43. if (arg1===false){
  44. numArr.splice(index,1,0)
  45. }
  46. }
  47. )
  48. //单个商品总金额数组
  49. let amountArr= numArr.map((item,index)=>item*priceArr[index])
  50. //计算总数量:
  51. function allNum(arg){
  52. return arg.reduce((arg1,arg2)=>arg1+arg2);
  53. }
  54. //计算总金额:
  55. function allPrice(arg){
  56. return arg.reduce((arg1,arg2)=>arg1+arg2)
  57. }
  58. //写入总数量到页面
  59. document.querySelector('.total-num').textContent=allNum(numArr)
  60. //写入总金额到页面
  61. document.querySelector('.total-amount').textContent=allNum(amountArr)
  62. //单个商品总金额
  63. document.querySelectorAll('.amount').forEach((arg1,arg2)=>arg1.textContent=amountArr1[arg2])
  64. }
  65. // 当页面加载的时候自动计算
  66. window.onload=autoCalc;
  67. //数量改变时自动计算:
  68. nums.forEach(num => (num.onchange=autoCalc))
  69. </script>
批改老师:PHPzPHPz

批改状态:合格

老师批语:
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学