vue.js实现简单购物车功能


Posted in Javascript onMay 30, 2020

本文实例为大家分享了vue.js实现简单购物车的具体代码,供大家参考,具体内容如下

这次我将给大家带来一个vue.js实现购物车的小项目,如有不足请严厉指出。

购物车功能有:全选和选择部分商品,选中商品总价计算,商品移除,以及调整购买数量等功能。

js主要有以下方法

加函数,减函数,手动修改数量判断库存函数,总价格计算函数,单选事件,全选事件,一共分为6个事件

具体效果如下图

vue.js实现简单购物车功能

代码在这里

main.js

'use strict'
 
var app = new Vue({
 el: '#app',
 data: {
 list: [
  {
  id: 1,
  name: 'iPhone 7',
  price: 6188,
  count: 1,
  check: true,
  },
  {
  id: 2,
  name: 'iPad Pro',
  price: 5888,
  count: 1,
  check: false,
  },
  {
  id: 3,
  name: 'MacBook Pro',
  price: 21488,
  count: 1,
  check: true,
  },
 ]
 },
 methods: {
 remove: function (index) { //移除商品
  this.list.splice(index, 1);
 },
 reduce: function (index) { //减少商品
  this.list[index].count --;
 },
 add: function (index) { //增加商品
  this.list[index].count ++;
 },
 selAll: function () { //商品全选
  let isAll = document.querySelector('#all');
 
  if (isAll.checked == true) {
  this.list.forEach(function(item, index) {
   item.check = true;
  }) 
  } else {
  this.list.forEach(function(item, index) {
   item.check = false;
  }) 
  }
 }
 },
 computed: {
 totalPrices: function () { //计算总价
  let totalPrices = 0;
 
  this.list.forEach(function (val, index) {
  if (val.check == true)
   totalPrices += parseFloat(val.price * val.count);
  })
 
  return totalPrices.toString().replace(/\B(?=(\d{3})+$)/g, ','); //每三位数中间加一个‘,'
 }
 }
})

index.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
 <link rel="stylesheet" href="main.css" >
</head>
<body>
<div id="app" v-cloak>
 <template v-if="list.length">
 <table>
  <thead>
  <tr>
   <th>全选<input id="all" @click="selAll" type="checkbox" checked></th>
   <th>商品名称</th>
   <th>商品单价</th>
   <th>购买数量</th>
   <th>操作</th>
  </tr>
  </thead>
  <tbody>
  <template v-for="(item, index) in list">
   <tr>
   <td>
    <input type="checkbox" :checked="item.check" @click="item.check = !item.check">
   </td>
   <td>
    {{ item.name }}
   </td>
   <td>
    {{ item.price }}
   </td>
   <td>
    <button @click="reduce(index)" :disabled="item.count == 1">-</button>
    {{ item.count }}
    <button @click="add(index)">+</button>    
   </td>
   <td>
    <button @click="remove(index)">移除</button>
   </td>
   </tr>
  </template>
  </tbody>
 </table>
 <div>总价: ¥ {{ totalPrices }}</div>
 </template>
 <template v-else>
 购物车没有商品
 </template>
</div>
 
<script src="vue.js"></script>
<script src="main.js"></script>
</body>
</html>

main.css

[v-cloak] {
 display: none; 
}
 
#app {
 width: 500px;
 margin: 0 auto;
}
 
table {
 width: 100%;
 border: 1px solid #444;
 border-collapse: collapse;
}
 
th, td {
 padding: 8px 16px;
 border: 1px solid #444;
 text-align: left;
}
 
th {
 background: #89abd3;
 color: rgb(214, 224, 235);
 font-weight: 600;
 white-space: nowrap;
}

更多文章可以点击《Vue.js前端组件学习教程》学习阅读。

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

更多vue学习教程请阅读专题《vue实战教程》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery操作复选框checkbox的方法汇总
Feb 05 Javascript
JS+CSS实现的蓝色table选项卡效果
Oct 08 Javascript
jQuery控制DIV层实现由大到小,由远及近动画变化效果
Oct 09 Javascript
Vue.js学习笔记之 helloworld
Aug 14 Javascript
jQuery组件easyui基本布局实现代码
Aug 25 Javascript
JS实现的数字格式化功能示例
Feb 10 Javascript
详谈Angular 2+ 的表单(一)之模板驱动型表单
Apr 25 Javascript
Node.js对MongoDB数据库实现模糊查询的方法
May 03 Javascript
解决html input验证只能输入数字,不能输入其他的问题
Jul 21 Javascript
vue.js或js实现中文A-Z排序的方法
Mar 08 Javascript
使用eslint和githooks统一前端风格的技巧
Jul 29 Javascript
vue代码分块和懒加载非必要资源文件
Apr 11 Vue.js
vue实现简单学生信息管理
May 30 #Javascript
vue实现学生信息管理系统
May 30 #Javascript
vue实现在线学生录入系统
May 30 #Javascript
VueJS实现用户管理系统
May 29 #Javascript
如何在vue中使用jointjs过程解析
May 29 #Javascript
vue实现信息管理系统
May 30 #Javascript
微信小程序语音同步智能识别的实现案例代码解析
May 29 #Javascript
You might like
5.PHP的其他功能
2006/10/09 PHP
对淘宝URL中ID提取的PHP代码
2013/09/01 PHP
php计算当前程序执行时间示例
2014/04/24 PHP
PHP编程中的常见漏洞和代码实例
2014/08/06 PHP
PHP pthreads v3下同步处理synchronized用法示例
2020/02/21 PHP
10个实用的脚本代码工具
2010/05/04 Javascript
基于jquery的设置页面文本框 只能输入数字的实现代码
2011/04/19 Javascript
商城常用滚动的焦点图效果代码简单实用
2013/03/28 Javascript
让低版本浏览器支持input的placeholder属性(js方法)
2013/04/03 Javascript
关于jquery中全局函数each使用介绍
2013/12/10 Javascript
js实现回放拖拽轨迹从过程上进行分析
2014/06/26 Javascript
JQuery中$(document)是什么意思有什么作用
2014/07/21 Javascript
微信小程序中实现一对多发消息详解及实例代码
2017/02/14 Javascript
JS实现图片放大缩小的方法
2017/02/15 Javascript
bootstrap table动态加载数据示例代码
2017/03/25 Javascript
angularjs2中父子组件的数据传递的实例代码
2017/07/05 Javascript
微信小程序实现动态设置页面标题的方法【附源码下载】
2017/11/29 Javascript
解决vue this.$forceUpdate() 处理页面刷新问题(v-for循环值刷新等)
2018/07/26 Javascript
JS实现DOM节点插入操作之子节点与兄弟节点插入操作示例
2018/07/30 Javascript
JSON.stringify()方法讲解
2019/01/31 Javascript
d3.js实现图形拖拽
2019/12/19 Javascript
vue.js实现简单购物车功能
2020/05/30 Javascript
Python中字典和JSON互转操作实例
2015/01/19 Python
Python第三方库的安装方法总结
2016/06/06 Python
python list元素为tuple时的排序方法
2018/04/18 Python
python模块smtplib实现纯文本邮件发送功能
2018/05/22 Python
如何使用django的MTV开发模式返回一个网页
2019/07/22 Python
使用matlab或python将txt文件转为excel表格
2019/11/01 Python
pandas factorize实现将字符串特征转化为数字特征
2019/12/19 Python
Python调用Windows命令打印文件
2020/02/07 Python
golang/python实现归并排序实例代码
2020/08/30 Python
HTML5实现页面切换激活的PageVisibility API使用初探
2016/05/13 HTML / CSS
信息技术培训感言
2014/03/06 职场文书
外贸会计专业自荐信
2014/06/22 职场文书
开学季:喜迎新生,迎新标语少不了
2019/11/07 职场文书
三年级作文之小小梦想
2019/12/06 职场文书