vue实现购物车选择功能


Posted in Javascript onJanuary 10, 2020

使用vue制作一个购物车功能,只是一个测试版本,注重的是功能实现,界面并没有做好,数据也是模拟数据等

vue实现购物车选择功能

不说那么多,直接上代码

<template>
 <div id="app">
 
 全选<input type="checkbox" v-model="checkall" @change="check_all()">
 <div v-for="(item,index) in mylist" :key="index">
  <span>{{item.oname}}</span><input type="checkbox" v-model="item.this_all" @change="check_list(index)">
  <p v-for="(goods,nindex) in item.newlist" :key="nindex">
  <input type="checkbox" v-model="goods.check_one" @change="click_input(index,nindex)">{{goods.newname}}--{{goods.price}}元
  </p>
  
 </div>
 <p>总价:{{allprice}}</p>
 <button @click="btn()">提交订单</button>
 
 </div>
</template>
 
<script>
export default {
 name: 'App',
 data(){
  return{
   mylist:[
    {oname:"第一个",this_all:true,newlist:[{newname:"篮球",check_one:true,price:600},{newname:"足球",check_one:true,price:200},{newname:"滑雪",check_one:true,price:150}]},
    {oname:"第二个",this_all:true,newlist:[{newname:"西瓜",check_one:true,price:35},{newname:"桃子",check_one:true,price:20}]},
    {oname:"第三个",this_all:true,newlist:[{newname:"英雄联盟",check_one:true,price:200}]},
 
   ],
   checkall:true,
   allprice:0,
   cpmylist:[]
  }
 },
 mounted:function(){
  this.money();
 },
 
 methods: {
 money:function(){
 var that = this;
 this.allprice=0;
 that.mylist.forEach(item1 =>{
  item1.newlist.forEach(item2 =>{
  if(item2.check_one==true){
   that.allprice+=item2.price;
  }
  })
 })
 
 },
 check_all:function(){
 var that = this;
 that.mylist.forEach(item1 => {
  item1.this_all=that.checkall
  item1.newlist.forEach(item2 => {
  item2.check_one=that.checkall
  })
 });
 that.money();
 },
 
 abc:function(){
 var that = this;
  var aaa = that.mylist.filter(item2 =>{
  return item2.this_all==true
 })
 aaa.length==that.mylist.length ? that.checkall = true : that.checkall = false
 that.money();
 },
 
 check_list:function(i){
 var that = this;
 that.mylist[i].newlist.forEach(item1 =>{
  item1.check_one=that.mylist[i].this_all
 })
 that.abc();
 
 },
 
 click_input:function(i,j){
 var that = this;
 var checklist = that.mylist[i].newlist.filter(item1 =>{
  return item1.check_one==true
 })
 
 checklist.length==that.mylist[i].newlist.length ? that.mylist[i].this_all = true : that.mylist[i].this_all = false
 that.abc();
 
 },
 
 btn:function(){
 var that = this; 
 
 
 that.cpmylist=JSON.parse(JSON.stringify(that.mylist));
 that.cpmylist.filter(item1 =>{
  item1.newlist = item1.newlist.filter(item2 =>{
  return item2.check_one==true
  })
 })
 that.cpmylist=that.cpmylist.filter(item3 =>{
  return item3.newlist.length!=0
 })
 
 if(that.cpmylist.length==0){
  alert("请选择商品哦!")
 }else{
 
  console.log("★★★您购买的商品是:");
  that.cpmylist.forEach(item4 =>{
  console.log("----------"+item4.oname+"店铺----------");
  item4.newlist.forEach(item5 =>{
   console.log("——>:"+item5.newname);
  })
  })
 }
 }
 },
 
}
</script>
 
<style>
#app {
 font-family: 'Avenir', Helvetica, Arial, sans-serif;
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 text-align: center;
 color: #2c3e50;
 margin-top: 60px;
}
</style>

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

Javascript 相关文章推荐
js获取div高度的代码
Aug 09 Javascript
javascript循环变量注册dom事件 之强大的闭包
Sep 08 Javascript
JavaScript Scoping and Hoisting 翻译
Jul 03 Javascript
使用 js+正则表达式为关键词添加链接
Nov 11 Javascript
Javascript定义类(class)的三种方法详解
Mar 13 Javascript
使用Meteor配合Node.js编写实时聊天应用的范例
Jun 23 Javascript
Javascript实现前端简单的路由实例
Sep 11 Javascript
jQuery弹出遮罩层效果完整示例
Sep 13 Javascript
AngularJS过滤器filter用法实例分析
Nov 04 Javascript
js判断手机号是否正确并返回的实现代码
Jan 17 Javascript
使用vue-router在Vue页面之间传递数据的方法
Jul 15 Javascript
原生js实现点击按钮复制内容到剪切板
Nov 19 Javascript
webpack proxy 使用(代理的使用)
Jan 10 #Javascript
基于vue-draggable 实现三级拖动排序效果
Jan 10 #Javascript
bootstrap实现嵌套模态框的实例代码
Jan 10 #Javascript
jQuery操作动画完整实例分析
Jan 10 #jQuery
基于JavaScript判断两个对象内容是否相等
Jan 10 #Javascript
jQuery操作事件完整实例分析
Jan 10 #jQuery
jQuery操作元素追加内容示例
Jan 10 #jQuery
You might like
咖啡语言
2021/03/03 咖啡文化
Codeigniter检测表单post数据的方法
2015/03/21 PHP
详解在PHP的Yii框架中使用行为Behaviors的方法
2016/03/18 PHP
不用锚点也可以平滑滚动到页面的指定位置实现代码
2013/05/08 Javascript
Javascript调用函数方法的几种方式介绍
2015/03/20 Javascript
js生成随机数的方法实例
2015/10/16 Javascript
跟我学习javascript的循环
2015/11/18 Javascript
Bootstrap 实现查询的完美方法
2016/10/26 Javascript
树结构之JavaScript
2017/01/24 Javascript
利用canvas实现的加载动画效果实例代码
2017/07/05 Javascript
webpack之devtool详解
2018/02/10 Javascript
在angularJs中进行数据遍历的2种方法
2018/10/08 Javascript
微信小程序如何实现五星评价功能
2019/10/15 Javascript
[02:53]2018年度DOTA2最佳战队-完美盛典
2018/12/17 DOTA
[05:53]敌法师的金色冠名ID"BurNIng",是传说,是荣耀
2020/07/11 DOTA
深入理解python中的浅拷贝和深拷贝
2016/05/30 Python
Python实现类似比特币的加密货币区块链的创建与交易实例
2018/03/20 Python
windows下添加Python环境变量的方法汇总
2018/05/14 Python
详解Python的循环结构知识点
2019/05/20 Python
python实现列表中最大最小值输出的示例
2019/07/09 Python
Python利用matplotlib绘制约数个数统计图示例
2019/11/26 Python
使用keras和tensorflow保存为可部署的pb格式
2020/05/25 Python
matplotlib教程——强大的python作图工具库
2020/10/15 Python
CSS3 clip-path 用法介绍详解
2018/03/01 HTML / CSS
你应该知道的30个css选择器
2014/03/19 HTML / CSS
详解利用canvas实现环形进度条的方法
2019/06/12 HTML / CSS
元旦活动感言
2014/03/08 职场文书
道德之星事迹材料
2014/05/03 职场文书
走群众路线学习笔记
2014/11/06 职场文书
2014年学校体育工作总结
2014/12/08 职场文书
CSS 文字装饰 text-decoration & text-emphasis 详解
2021/04/06 HTML / CSS
关于mysql中时间日期类型和字符串类型的选择
2021/11/27 MySQL
HTML常用标签超详细整理
2022/03/19 HTML / CSS
Nebula Graph解决风控业务实践
2022/03/31 MySQL
JS轻量级函数式编程实现XDM二
2022/06/16 Javascript
Win11 22H2 2022怎么更新? 获得Win1122H22022版本升级技巧
2022/09/23 数码科技