js简易版购物车结算

本文介绍如何使用JavaScript实现一个基本的购物车结算功能。通过添加商品、删除商品和调整数量,动态计算购物车总价,涉及DOM操作和简单的数据处理。
摘要由CSDN通过智能技术生成
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>周某人前端5.14作业</title>
    <style>
      .add{
   
        margin: 0 5px;
      }
    </style>
	</head>
	<body>
		<table border="1" width="50%">
			<tr>
				<td>编号</td>
				<td>名称</td>
				
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的购物车结算页面的JS实现: 1. 获取页面元素 首先需要获取页面中的各个元素,比如商品数量、单价、小计等。 ```javascript var numInputs = document.getElementsByClassName('cart-num'); var priceSpans = document.getElementsByClassName('cart-price'); var subtotalSpans = document.getElementsByClassName('cart-subtotal'); var totalSpan = document.getElementById('cart-total'); var checkoutButton = document.getElementById('checkout-btn'); ``` 2. 绑定事件 接下来需要给每个商品数量输入框绑定事件,当输入框的值改变时更新小计和总计。 ```javascript for (var i = 0; i < numInputs.length; i++) { numInputs[i].addEventListener('change', function() { var num = parseInt(this.value); var price = parseFloat(priceSpans[i].innerText); var subtotal = num * price; subtotalSpans[i].innerText = subtotal.toFixed(2); updateTotal(); }); } ``` 3. 更新总计 更新小计后需要更新总计,计算所有商品小计的和。 ```javascript function updateTotal() { var subtotal = 0; for (var i = 0; i < subtotalSpans.length; i++) { subtotal += parseFloat(subtotalSpans[i].innerText); } totalSpan.innerText = subtotal.toFixed(2); } ``` 4. 结算按钮事件 最后需要给结算按钮绑定事件,当用户点击结算按钮时,弹出提示框显示总价。 ```javascript checkoutButton.addEventListener('click', function() { var total = parseFloat(totalSpan.innerText); alert('您需要支付:' + total.toFixed(2) + '元'); }); ``` 完整代码如下: ```javascript var numInputs = document.getElementsByClassName('cart-num'); var priceSpans = document.getElementsByClassName('cart-price'); var subtotalSpans = document.getElementsByClassName('cart-subtotal'); var totalSpan = document.getElementById('cart-total'); var checkoutButton = document.getElementById('checkout-btn'); for (var i = 0; i < numInputs.length; i++) { numInputs[i].addEventListener('change', function() { var num = parseInt(this.value); var price = parseFloat(priceSpans[i].innerText); var subtotal = num * price; subtotalSpans[i].innerText = subtotal.toFixed(2); updateTotal(); }); } function updateTotal() { var subtotal = 0; for (var i = 0; i < subtotalSpans.length; i++) { subtotal += parseFloat(subtotalSpans[i].innerText); } totalSpan.innerText = subtotal.toFixed(2); } checkoutButton.addEventListener('click', function() { var total = parseFloat(totalSpan.innerText); alert('您需要支付:' + total.toFixed(2) + '元'); }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值