Vue.js实现的购物车功能详解


Posted in Javascript onJanuary 27, 2019

本文实例讲述了Vue.js实现的购物车功能。分享给大家供大家参考,具体如下:

使用计算属性,内置指令,方法等基础知识开发购物车。

需求分析:展示一个已经加入购物车的商品列表,包含商品名称、商品单价、购买数量和操作,以及最后确定是否选中商品的功能,总价格为选中商品的价格,够买数量可以增加减少,商品可以从购物车中移除。效果如图所示:

Vue.js实现的购物车功能详解

——实例来自《Vue.js实战》第五章

逻辑整理:vue实例定义一个数组list存放商品信息,定义方法与减少按钮,增加按钮等联系,动态改变商品数量,通过handleRemove()移除list中的值;利用each()遍历所有type='checkbox'input,修改它们的状态,最后用totalPrices()计算商品总价格。

index.html

<div id="app">
    <template v-if="list.length">
      <table>
        <thead>
          <tr>
            <th></th>
            <th>商品名称</th>
            <th>商品单价</th>
            <th>购买数量</th>
            <th>操作</th>
            <th><input type="checkbox" name="list" @click="checkBox()" id="checkBox"></th>
          </tr>
        </thead>
        <tbody>
          <tr v-for="(item, index) in list">
            <td>{{ index + 1 }}</td>
            <td>{{ item.name }}</td>
            <td>{{ item.price }}</td>
            <td>
                <button
                  @click="handleReduce(index)"
                  :disabled="item.count === 1" class="btn"> - </button>
                {{ item.count }}
                <button @click="handleAdd(index)" class="btn"> + </button>
            </td>
            <td>
                <button @click="handleRemove(index)" class="btns">移除</button>
            </td>
            <td style="text-align: center;">
                <input type="checkbox" name="list" @click="totalPrices()">
            </td>
          </tr>
        </tbody>
      </table>
      <div id="price">总价:¥{{totalPrice}}</div>
    </template>
    <div v-else>购物车为空</div>
</div>

style.css

*{
  margin: 0px;
  padding: 0px;
}
[v-cloak] {
  display: none;
}
#app{
  width: 200px;
  height: 200px;
  margin: 10px auto;
  text-align: center;
}
#price{
  width: 457px;
  height: 40px;
  border: 1px solid #e9e9e9;
  border-top: 0;
  line-height: 40px;
}
table{
  border: 1px solid #e9e9e9;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}
th,td{
  padding: 8px 16px;
  border:1px solid #e9e9e9e9;
  text-align: left;
}
th{
  background: #f7f7f7;
  color: #5c6c77;
  font-weight: 600;
  white-space: nowrap;
}
.btn{
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border:1px solid #cccccc;
  background: #ffffff;
  color: #778899;
}
.btns{
  width: 40px;
  height: 20px;
  border-radius: 5px;
  border:1px solid #cccccc;
  background: #ffffff;
  color: #778899;
  line-height: 20px;
}

app.js

var app=new Vue({
      el:'#app',
      data:{
        list: [
          {
            id:1,
            name:'iPhone 7',
            price:6188,
            count:1
          },
          {
            id:2,
            name:'iPad Pro',
            price:5888,
            count:1
          },
          {
            id:3,
            name:'MaxBook Pro',
            price:21488,
            count:1
          }
        ],
        totalPrice: 0
      },
      methods:{
        handleReduce: function (index) {//减少按钮
          if(this.list[index].count === 1){
            return;
          }
          this.list[index].count--;
          this.$options.methods.totalPrices();
        },
        handleAdd: function (index) {//增加按钮
          this.list[index].count++;
          this.$options.methods.totalPrices();
        },
        handleRemove: function (index) {//移除按钮
          this.list.splice(index, 1);
          $("tr").eq(index+1).remove("input[type='checkbox']");
          this.$options.methods.totalPrices();
        },
        checkBox: function (){//选中状态
          if($("#checkBox").is(':checked')==true){
            $("input[type='checkbox']").each(function(){
              $("input[type='checkbox']").attr("checked",true);
            });
          }else{
            $("input[type='checkbox']").each(function(){
              $("input[type='checkbox']").attr("checked",false);
            });
          }
          this.$options.methods.totalPrices();
        },
        totalPrices: function (){//计算总价格
          var total = 0;
          for(var i = 0;i < app.list.length;i++){
            var item = app.list[i];
            if($("input[type='checkbox']").eq(i+1).is(':checked')){
              total += item.price * item.count;
            }
          }
          app.totalPrice = total.toString().replace(/\B(?=(\d{3})+$)/g,',');
        }
      }
});

GitHub地址:https://github.com/GitHubVikas/Yao/tree/master/DemoOne

希望本文所述对大家vue.js程序设计有所帮助。

Javascript 相关文章推荐
用js实现随机返回数组的一个元素
Aug 13 Javascript
extjs 初始化checkboxgroup值的代码
Sep 21 Javascript
Jquery原生态实现表格header头随滚动条滚动而滚动
Mar 18 Javascript
JavaScript返回网页中超链接数量的方法
Apr 03 Javascript
js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
Dec 27 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
Jun 19 Javascript
微信小程序-getUserInfo回调的实例详解
Oct 27 Javascript
JavaScript使用百度ECharts插件绘制饼图操作示例
Nov 26 Javascript
微信小程序获取复选框全选反选选中的值(实例代码)
Dec 17 Javascript
基于vue3.0.1beta搭建仿京东的电商H5项目
May 06 Javascript
VueQuillEditor富文本上传图片(非base64)
Jun 03 Javascript
angular异步验证器防抖实例详解
Mar 31 Javascript
JS温故而知新之变量提升和时间死区
Jan 27 #Javascript
vue组件文档(.md)中如何自动导入示例(.vue)详解
Jan 25 #Javascript
命令行批量截图Node脚本示例代码
Jan 25 #Javascript
Node.js 进程平滑离场剖析小结
Jan 24 #Javascript
Vue.js样式动态绑定实现小结
Jan 24 #Javascript
实例讲解JavaScript预编译流程
Jan 24 #Javascript
实例讲解vue源码架构
Jan 24 #Javascript
You might like
通过修改Laravel Auth使用salt和password进行认证用户详解
2017/08/17 PHP
用javascript来实现动画导航效果的代码
2007/12/16 Javascript
js 图片缩放(按比例)控制代码
2009/05/27 Javascript
JS中的public和private对象,即static修饰符
2012/01/18 Javascript
Javascript自定义排序 node运行 实例
2013/06/05 Javascript
jquery css 设置table的奇偶行背景色示例
2014/06/03 Javascript
WEB前端设计师常用工具集锦
2014/12/09 Javascript
JQuery解析XML数据的几个简单实例
2016/05/18 Javascript
微信小程序中使元素占满整个屏幕高度实现方法
2016/12/14 Javascript
JS实现数组简单去重及数组根据对象中的元素去重操作示例
2018/01/05 Javascript
20个最常见的jQuery面试问题及答案
2018/05/23 jQuery
vue + webpack如何绕过QQ音乐接口对host的验证详解
2018/07/01 Javascript
webpack4 CSS Tree Shaking的使用
2018/09/03 Javascript
JS 验证码功能的三种实现方式
2018/11/26 Javascript
JavaScript 监听组合按键思路及代码实现
2020/07/28 Javascript
在Vue中获取自定义属性方法:data-id的实例
2020/09/09 Javascript
Python实现将SQLite中的数据直接输出为CVS的方法示例
2017/07/13 Python
python实现二分查找算法
2017/09/21 Python
tensorflow构建BP神经网络的方法
2018/03/12 Python
利用python将json数据转换为csv格式的方法
2018/03/22 Python
python多线程之事件Event的使用详解
2018/04/27 Python
对python遍历文件夹中的所有jpg文件的实例详解
2018/12/08 Python
Python实现的逻辑回归算法示例【附测试csv文件下载】
2018/12/28 Python
pyqt5让图片自适应QLabel大小上以及移除已显示的图片方法
2019/06/21 Python
Python 实现输入任意多个数,并计算其平均值的例子
2019/07/16 Python
Python 爬虫实现增加播客访问量的方法实现
2019/10/31 Python
简单整理HTML5的基本特性和语法
2016/02/18 HTML / CSS
基于HTML5实现类似微信手机摇一摇功能(计算摇动次数)
2017/07/24 HTML / CSS
香蕉共和国工厂店:Banana Republic Factory
2018/06/09 全球购物
澳大利亚波希米亚风时尚品牌:Tree of Life
2019/09/15 全球购物
用C或者C++语言实现SOCKET通信
2015/02/24 面试题
网络事业创业计划书范文
2014/01/09 职场文书
工作疏忽检讨书
2014/01/25 职场文书
浪漫婚礼主持词开场白
2015/11/24 职场文书
如何使用SQL Server语句创建表
2022/04/12 SQL Server
Beekeeper Studio开源数据库管理工具比Navicat更炫酷
2022/06/21 数据库