今天给各位分享前端实现购物车js代码的知识,其中也会对用js怎么实现购物车的功能进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
jquery 实现加入购物车功能
参考以下代码:
注意需要导入jquery.js.
!DOCTYPE html
html
head
title购物车----jQuery/title
meta charset="utf-8" /
style type="text/css"
h1 {
text-align:center;
}
table {
margin:0 auto;
width:60%;
border:2px solid #aaa;
border-collapse:collapse;
}
table th, table td {
border:2px solid #aaa;
padding:5px;
}
th {
background-color:#eee;
}
/style
script type="text/javascript" src="./js/jquery.js"/script
script type="text/javascript"
function add_shoppingcart(btn){//将btn(dom)转换为jQuery对象
//先获取商品名字和单价还有库存以备后面使用
var $tds = $(btn).parent().siblings();
//$tds.eq(0)是jQuery对象 $tds[0]是DOM对象
var name = $tds.eq(0).html();//string
var price = $tds.eq(1).html();//string
var stock = $tds.eq(3).html();//string
//查看库存是否还有=0
if(stock = 0){
return;
}
//无论购物车中是否有该商品,库存都要-1
$tds.eq(3).html(--stock);
//在添加之前确定该商品在购物车中是否存在,若存在,则数量+1,若不存在则创建行
var $trs = $("#goodstr");
for(var i=0;i$trs.length;i++){
var $gtds = $trs.eq(i).children();
var gName = $gtds.eq(0).html();
if(name == gName){//若存在
var num = parseInt($gtds.eq(2).children().eq(1).val());
$gtds.eq(2).children().eq(1).val(++num);//数量+1
//金额从新计算
$gtds.eq(3).html(price*num);
return;//后面代码不再执行
}
}
//若不存在,创建后追加
var li =
"tr"+
"td"+name+"/td"+
"td"+price+"/td"+
"td align='center'"+
"input type='button' value='-' onclick='decrease(this);'/ "+
"input type='text' size='3' readonly value='1'/ "+
"input type='button' value='+' onclick='increase(this);'/"+
"/td"+
"td"+price+"/td"+
"td align='center'"+
"input type='button' value='x' onclick='del(this);'/"+
"/td"+
"/tr";
//追加到#goods后面
$("#goods").append($(li));
//总计功能
total();
}
//辅助方法--单击购物车中的"+" "-" "x"按钮是找到相关商品所在td,以jQuery对象返回
function findStock(btn){
var name = $(btn).parent().siblings().eq(0).html();//获取商品名字
//注意table默认有行分组,若此处使用 $("#table1tr:gt(0)")则找不到任何tr
var $trs = $("#table1tbodytr:gt(0)");
for(var i=0;i$trs.length;i++){
var fName = $trs.eq(i).children().eq(0).html();
if(name == fName){//找到匹配的商品
return $trs.eq(i).children().eq(3);
}
}
}
//增加"+"功能
function increase(btn){
//获取该商品库存看是否=0
var $stock = findStock(btn);
var stock = $stock.html();
if(stock = 0){
return;
}
//库存-1
$stock.html(--stock);
//购物车数据改变
var $td = $(btn).prev();
var num = parseInt($td.val());//number
//num此时为number类型(在计算时会自动转换为number类型)
$td.val(++num);
//获取单价,再加计算前要先转换为number类型
var price = parseInt($(btn).parent().prev().html());
$(btn).parent().next().html(num*price);
//总计功能
total();
}
//减少"-"功能
function decrease(btn){
//该商品数量=1时候不能再减少
var num = parseInt($(btn).next().val());
if(num = 1){
return;
}
var $stock = findStock(btn);
//库存+1
var stock = $stock.html();
$stock.html(++stock);
//商品数量-1
$(btn).next().val(--num);
//从新计算金额
var price = parseInt($(btn).parent().prev().html());
$(btn).parent().next().html(price*num);
//总计功能
total();
}
//"x"删除按钮功能
function del(btn){
//将商品数量归还库存
var $stock = findStock(btn);
var stock = parseInt($stock.html());
var num = parseInt($(btn).parent().prev().prev().children().eq(1).val());
$stock.html(num + stock);
//清空改行商品列表
$(btn).parent().parent().remove();
//总计功能
total();
}
//总计功能
function total(){
//获取所有购物车中的trs
var $trs = $("#goods tr");
var amount = 0;
for(var i=0;i$trs.length;i++){
var money = parseInt($trs.eq(i).children().eq(3).html());
amount += money;
}
//写入总计栏
$("#total").html(amount);
}
/script
/head
body
h1真划算/h1
table id="table1"
tr
th商品/th
th单价(元)/th
th颜色/th
th库存/th
th好评率/th
th操作/th
/tr
tr
td罗技M185鼠标/td
td80/td
td黑色/td
td5/td
td98%/td
td align="center"
input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/
/td
/tr
tr
td微软X470键盘/td
td150/td
td黑色/td
td9028/td
td96%/td
td align="center"
input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/
/td
/tr
tr
td洛克iphone6手机壳/td
td60/td
td透明/td
td672/td
td99%/td
td align="center"
input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/
/td
/tr
tr
td蓝牙耳机/td
td100/td
td蓝色/td
td8937/td
td95%/td
td align="center"
input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/
/td
/tr
tr
td金士顿U盘/td
td70/td
td红色/td
td482/td
td100%/td
td align="center"
input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/
/td
/tr
/table
h1购物车/h1
table
thead
tr
th商品/th
th单价(元)/th
th数量/th
th金额(元)/th
th删除/th
/tr
/thead
tbody id="goods"
/tbody
tfoot
tr
td colspan="3" align="right"总计/td
td id="total"/td
td/td
/tr
/tfoot
/table
/body
/html
最终效果图:
web前端购物车功能实现
其实思路都是很简单的,如果你要纯前端的实现,那用Javascript或者jquery就可以做了,如果想前后端联动,那么具体数据操作你就提交到后台,然后后台重新返回页面就可以了
很奇怪的js,ajax的问题,关于添加到购物车及点击删除的,就类似京东商城的那样。
初步怀疑你的删除事件绑定有问题:新加入的DOM元素未绑定到事件。这种情况应该使用事件委派来做,你用 jQuery 吗?假设你的购物车列表的 HTML 结构如下:
ul id="cartList"
li
购物车商品1
button删除/button
/li
li
购物车商品2
button删除/button
/li
……
/ul
则删除购物车商品的代码为(用了 jQuery):
$('#cartList').on('click', 'button', function() { // 委派 button 的点击事件
$(this).parent().remove(); // 移除购物车里当前商品
});
前端实现购物车js代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于用js怎么实现购物车的功能、前端实现购物车js代码的信息别忘了在本站进行查找喔。
温馨提示
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请后台提交工单处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请后台提交工单!
【免责声明】:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
【关于转载】:
本站尊重互联网版权体系,本站部分图片、文章大部分转载于互联网、所有内容不代表本站观点、不对文章中的任何观点负责、转载的目的只用于给网民提供信息阅读,无任何商业用途,所有内容版权归原作者所有
如本站(文章、内容、图片、视频)任何资料有侵权,先说声抱歉;麻烦您请联系请后台提交工单,我们会立即删除、维护您的权益。非常感谢您的理解。
【附】:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!
注:本站资源来自网络转载,版权归原作者和公司所有,如果有侵犯到您的权益,请第一时间联系我们处理!
-----------------------------------------------------------------------------------------------------------
【版权声明】:
一、本站致力于为源码爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、如有内容侵犯您的版权或其他利益的,请编辑邮件并加以说明发送到站长邮箱。站长会进行审查之后,情况属实的会在三个工作日内为您删除。
-----------------------------------------------------------------------------------------------------------
源码村资源网 » 前端实现购物车js代码(用js怎么实现购物车的功能)
1 评论