Vuejs实现购物车功能


Posted in Javascript onNovember 05, 2017

开始更新前端框架Vue.JS的相关博客。

功能概述

学习了Vue.JS的一些基础知识,现在利用指令、数据绑定这些基础知识开发一个简单的购物车功能。功能要点如下:
(1)展示商品的名称、单价和数量;
(2)商品的数量可以增加和减少;
(3)购物车的总价要实时更新,即数量发生变动,总价也要相应的改变;
(4)商品可以从购物车中移除;
(5)具有选择功能,只计算选中的商品的总价。

上一张截图,如下:

Vuejs实现购物车功能

代码

代码分成三部分,分别是HTML、JS、CSS。关键的是HTML和JS。

HTML

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>Vue 购物车</title>
 <script src="../js/vue.min.js"></script>
 <link href="../css/cart.css" rel="external nofollow" rel="stylesheet">
 </head>
 <body>
 <div id="app" v-cloak>
  <template v-if="list.length">
  <table>
   <thead>
   <tr>
    <th><input type="checkbox" v-on:click="swapCheck" v-model="checked"></th>
    <th>商品名称</th>
    <th>商品单价</th>
    <th>商品数量</th>
    <th>操作</th>
   </tr>   
   </thead>
   <tbody>
   <tr v-for="(item,index) in list">
    <td><input type="checkbox" v-model="selectList" :id="item.id" :value="index" name="selectList" ></td>
    <td>{{ item.name }}</td>
    <td>{{ item.price }}</td>
    <td>
    <button @click="handleReduce(index)" :disabled="item.count === 1">-</button>
    {{ item.count }}
    <button @click="handleAdd(index)">+</button>
    </td>
    <td><button @click="handleRemove(index)">移除</button></td>
   </tr>
   </tbody>
  </table>
  <div>总价:¥ {{ totalPrice }}</div>
  </template>
  <div v-else>购物车为空!</div>
 </div>

 <script src="../js/cart.js"></script>
 </body>
</html>

JS

var app = new Vue({
 el:'#app',
 data:{
 list:[
  {
  id:1,
  name:'iPhone 8',
  price:8888,
  count:1
  },
  {
  id:2,
  name:'Huwei Mate10',
  price:6666,
  count:1
  },
  {
  id:3,
  name:'Lenovo',
  price:6588,
  count:1
  }
 ],
 selectList:[],
 checked:false
 },
 computed:{
 totalPrice:function(){
  var total = 0;
  for(var i = 0,len = this.selectList.length;i < len;i++){
  var index = this.selectList[i];
  var item = this.list[index];
  if(item){
   total += item.price * item.count;
  }
  else{
   continue;
  }

  }
  return total.toString().replace(/\B(?=(\d{3})+$)/g,',');
 }
 },
 methods:{
 handleReduce:function(index){
  var item = this.list[index];
  if(item.count < 2){
  return;
  }
  item.count--;
 },
 handleAdd:function(index){
  var item = this.list[index];
  item.count++;
 },
 handleRemove:function(index){
  this.list.splice(index,1);
 },
 swapCheck:function(){

  var selectList = document.getElementsByName('selectList');
  var len = selectList.length;
  if(this.checked){
  for(var i = 0;i < len;i++){
   var item = selectList[i];
   item.checked = false;
  }
  this.checked = false;
  this.selectList = [];
  }
  else{
  for(i = 0;i < len;i++){
   item = selectList[i];
   if(item.checked === false){
   item.checked = true;
   this.selectList.push(selectList[i].value);
   }
  }
  this.checked = true;

  }
 }
 }
});

CSS

[v-cloak]{
 display: none;
}

table{
 border: 1px solid black;
 border-collapse: collapse;
 border-spacing: 0;
 empty-cells: show;
}

th,td{
 padding: 8px 16px;
 border:1px solid black;
 text-align: center;
}

th{
 background-color: gray;
}

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

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

Javascript 相关文章推荐
javascript 文本框水印/占位符(watermark/placeholder)实现方法
Jan 15 Javascript
jquery中对于批量deferred的处理方法
Jan 22 Javascript
js正则表达式匹配数字字母下划线等
Apr 14 Javascript
js淡入淡出焦点图幻灯片效果代码分享
Sep 08 Javascript
JavaScript中字面量与函数的基本使用知识
Oct 20 Javascript
JavaScript驾驭网页-获取网页元素
Mar 24 Javascript
canvas实现图像截取功能
Feb 06 Javascript
EasyUI的TreeGrid的过滤功能的解决思路
Aug 08 Javascript
关于react-router/react-router-dom v4 history不能访问问题的解决
Jan 08 Javascript
JointJS流程图的绘制方法
Dec 03 Javascript
PHP实现基于Redis的MessageQueue队列封装操作示例
Feb 02 Javascript
Typescript的三种运行方式(小结)
Sep 18 Javascript
JavaScript实现音乐自动切换和轮播
Nov 05 #Javascript
vue+node+webpack环境搭建教程
Nov 05 #Javascript
JavaScript实现三级级联特效
Nov 05 #Javascript
angular中不同的组件间传值与通信的方法
Nov 04 #Javascript
详解使用React全家桶搭建一个后台管理系统
Nov 04 #Javascript
JavaScript中立即执行函数实例详解
Nov 04 #Javascript
Vue全家桶实践项目总结(推荐)
Nov 04 #Javascript
You might like
理解php原理的opcodes(操作码)
2010/10/26 PHP
如何解决CI框架的Disallowed Key Characters错误提示
2013/07/05 PHP
浅谈Laravel中的一个后期静态绑定
2017/08/11 PHP
PHP var关键字相关原理及使用实例解析
2020/07/11 PHP
php自动加载代码实例详解
2021/02/26 PHP
在js中使用&quot;with&quot;语句中跨frame的变量引用问题
2007/03/08 Javascript
Dojo 学习要点
2010/09/03 Javascript
基于JQuery的模拟苹果桌面Dock效果(稳定版)
2012/10/15 Javascript
js中数组Array的一些常用方法总结
2013/08/12 Javascript
简单实现限制uploadify上传个数
2015/11/16 Javascript
jQuery动画效果图片轮播特效
2016/01/12 Javascript
JavaScript面向对象程序设计教程
2016/03/29 Javascript
Jquery Easyui对话框组件Dialog使用详解(14)
2016/12/19 Javascript
Iphone手机、安卓手机浏览器控制默认缩放大小的方法总结(附代码)
2017/08/18 Javascript
vue+springmvc导出excel数据的实现代码
2018/06/27 Javascript
详解从NodeJS搭建中间层再谈前后端分离
2018/11/13 NodeJs
小程序使用wxs解决wxml保留2位小数问题
2019/12/13 Javascript
javascript 模块依赖管理的本质深入详解
2020/04/30 Javascript
SpringBoot+Vue开发之Login校验规则、实现登录和重置事件
2020/10/19 Javascript
[14:03]2017DOTA2亚洲邀请赛开幕式:12神兵演绎水墨中华
2017/04/01 DOTA
python原始套接字编程示例分享
2014/02/21 Python
讲解Python中fileno()方法的使用
2015/05/24 Python
python中argparse模块用法实例详解
2015/06/03 Python
python编程嵌套函数实例代码
2018/02/11 Python
关于Python形参打包与解包小技巧分享
2019/08/24 Python
Pyecharts地图显示不完成问题解决方案
2020/05/11 Python
Django全局启用登陆验证login_required的方法
2020/06/02 Python
Python numpy大矩阵运算内存不足如何解决
2020/11/19 Python
英国最大的独立摄影零售商:Park Cameras
2019/11/27 全球购物
信息部岗位职责
2013/11/12 职场文书
物流专业大学生职业生涯规划书范文
2014/01/15 职场文书
安全生产一岗双责责任书
2014/07/28 职场文书
见习报告格式要求
2014/11/04 职场文书
教师党员群众路线教育实践活动心得体会
2014/11/04 职场文书
教师学期个人总结
2015/02/11 职场文书
通知函格式范文
2015/04/27 职场文书