vue实现购物车列表


Posted in Javascript onJune 30, 2020

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

功能:

  • 删除
  • 单选 全选
  • 增加数量 减少数量
  • 计算总价 计算数量
  • 搜索

代码:

<!DOCTYPE html>
<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title></title>
 <script src="./js/vue.js"></script>
 </head>
 <body>
 <div id="app">
   筛选:<input type="text" v-model="key">
 <table border="1" cellspacing="0" cellpadding="10">
 <tr>
  <th>
  <input type="checkbox" v-model="all" @change="checkAll()" >
  </th>
  <th>id</th>
  <th>书籍名称</th>
  <th>出版日期</th>
  <th>购买价格</th>
  <th>数量</th>
  <th>操作</th>
 </tr>
 <tr v-for="(item,index) in flist" :key="item.id">
  <td style="text-align: center;"><input type="checkbox" v-model="item.sel" ></td>
  <td>{{item.id}}</td>
  <td>{{item.name}}</td>
  <td>{{item.time}}</td>
  <td>{{item.price|prices}}</td>
  <td><button @click="item.num--" :disabled="item.num==1">-</button>{{item.num}}<button @click="item.num++">+</button></td>
  <td><button @click="delItem(item.id)">移除</button></td>
 </tr>
 <tr><td colspan="7">总价格:{{total.price|prices}} 选择数量:{{total.num}}</td></tr>
 </table>
 </div>
 <script>
 var vm = new Vue({
 el:"#app",
 data:{
     key:"",
  all:true,
  list:[
  {id:1,name:"小红书",time:"2018-8",price:188.99,num:1,sel:true},
  {id:2,name:"小烂熟",time:"2019-8",price:88.9,num:1,sel:true},
  {id:3,name:"小绿树",time:"2017-5",price:133.00,num:1,sel:true},
  {id:4,name:"发生的树",time:"2020-1",price:68.80,num:1,sel:true},
  {id:5,name:"奥古",time:"2015-4",price:555.50,num:1,sel:true },
  ]
 },
 methods:{
     delItem(item){
      var falg=window.confirm("确定要删除吗?");
      if(falg){
       this.list.splice(item-1,1)
      }
      
     },
     checkAll(){
      this.list.forEach(item=>item.sel=this.all)
     }
    },
    watch:{
     list:{
      handler:function(){
       this.all=this.list.every(item=>item.sel)
      },
      deep:true
     }
    },
    computed:{
     total:function(){
      var price=0;
      var num=0;
      this.list.forEach(item=>{
       if(item.sel){
        price+=item.num*item.price
        num+=item.num*1
       
       }
      })
      return ({price,num})
     },
     flist:function(){
      if(this.key===''){return this.list}
  return this.list.filter(item=>item.name.includes(this.key))
     }
    },
    filters:{
     prices:function(val,fix=2){
      val=val.toFixed(fix)
      val=""+val
      return "¥"+val
     }
    },

 
 })
 </script>
 </body>
</html>

vue实现购物车列表

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

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

Javascript 相关文章推荐
javascript面向对象入门基础详细介绍
Sep 05 Javascript
javascript截取字符串(通过substring实现并支持中英文混合)
Jun 24 Javascript
Jquery的hide及toggle方法让超链接慢慢消失
Sep 06 Javascript
node.js中的http.request.end方法使用说明
Dec 10 Javascript
jQuery图片特效插件Revealing实现拉伸放大
Apr 22 Javascript
jquery+css实现绚丽的横向二级下拉菜单-附源码下载
Aug 23 Javascript
JavaScript的ExtJS框架中表格的编写教程
May 21 Javascript
深入理解逻辑表达式的用法 与或非的用法
Jun 06 Javascript
AngularJS $injector 依赖注入详解
Sep 14 Javascript
jQuery使用JSONP实现跨域获取数据的三种方法详解
May 04 jQuery
js的对象与函数详解
Jan 21 Javascript
Vue基于vuex、axios拦截器实现loading效果及axios的安装配置
Apr 26 Javascript
vue实现简单图片上传
Jun 30 #Javascript
vue基于better-scroll仿京东分类列表
Jun 30 #Javascript
vue使用better-scroll实现滑动以及左右联动
Jun 30 #Javascript
vue基于better-scroll实现左右联动滑动页面
Jun 30 #Javascript
Postman动态获取返回值过程详解
Jun 30 #Javascript
JS简易计算器实例讲解
Jun 30 #Javascript
如何在postman中添加cookie信息步骤解析
Jun 30 #Javascript
You might like
PHP UTF8编码内的繁简转换类
2009/07/20 PHP
PHP中3种生成XML文件方法的速度效率比较
2012/10/06 PHP
PHP数据过滤的方法
2013/10/30 PHP
php银联网页支付实现方法
2015/03/04 PHP
thinkphp关于简单的权限判定方法
2017/04/03 PHP
让Laravel API永远返回JSON格式响应的方法示例
2018/09/05 PHP
thinkphp5.1 框架钩子和行为用法实例分析
2020/05/25 PHP
jQuery EasyUI API 中文文档 - ComboTree组合树
2011/10/11 Javascript
Vue.set()动态的新增与修改数据,触发视图更新的方法
2018/09/15 Javascript
webpack4与babel配合使es6代码可运行于低版本浏览器的方法
2018/10/12 Javascript
微信小程序实现签到功能
2018/10/31 Javascript
Vue Router 实现动态路由和常见问题及解决方法
2020/03/06 Javascript
jQuery实现简单日历效果
2020/07/05 jQuery
[00:27]DOTA2次级职业联赛 - Lilith战队宣传片
2014/12/01 DOTA
用Python中的wxPython实现最基本的浏览器功能
2015/04/14 Python
Python和C/C++交互的几种方法总结
2017/05/11 Python
简单了解Python中的几种函数
2017/11/03 Python
Python使用Matplotlib实现Logos设计代码
2017/12/25 Python
Python 循环语句之 while,for语句详解
2018/04/23 Python
Django中更改默认数据库为mysql的方法示例
2018/12/05 Python
python读取xlsx的方法
2018/12/25 Python
python实现三维拟合的方法
2018/12/29 Python
python同步两个文件夹下的内容
2019/08/29 Python
HTML5基于flash实现播放RTMP协议视频的示例代码
2020/12/04 HTML / CSS
Fashion Eyewear美国:英国线上设计师眼镜和太阳镜的零售商
2016/08/15 全球购物
耐克波兰官方网站:Nike波兰
2019/09/03 全球购物
日本即尚网:JSHOPPERS.com(支持中文)
2019/12/03 全球购物
英国礼品和生活方式品牌:Treat Republic
2020/11/21 全球购物
澳大利亚最受欢迎的超级商场每日优惠:Catch
2020/11/17 全球购物
新驾驶员个人自我评价
2014/01/03 职场文书
国贸专业的职业规划范文
2014/01/23 职场文书
《我要的是葫芦》教学反思
2014/02/23 职场文书
个人主要事迹材料
2014/08/26 职场文书
会计工作态度自我评价
2015/03/06 职场文书
微信小程序结合ThinkPHP5授权登陆后获取手机号
2021/11/23 PHP
SpringBoot使用ip2region获取地理位置信息的方法
2022/06/21 Java/Android