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 相关文章推荐
onkeypress字符按键兼容所有浏览器使用介绍
Apr 24 Javascript
IE中的File域无法清空使用jQuery重设File域
Apr 24 Javascript
jquery实现动画菜单的左右滚动、渐变及图形背景滚动等效果
Aug 25 Javascript
WebApi+Bootstrap+KnockoutJs打造单页面程序
May 16 Javascript
详解Vue.js——60分钟组件快速入门(上篇)
Dec 05 Javascript
微信公众号 摇一摇周边功能开发
Dec 08 Javascript
浅谈Angular的$q, defer, promise
Dec 20 Javascript
JS遍历对象属性的方法示例
Jan 10 Javascript
原生JavaScript实现AJAX、JSONP
Feb 07 Javascript
vue.js默认路由不加载linkActiveClass问题的解决方法
Dec 11 Javascript
Vuejs 2.0 子组件访问/调用父组件的方法(示例代码)
Feb 08 Javascript
AJAX学习笔记
May 18 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
造势之举?韩国总统候选人发布《星际争霸》地图
2017/04/22 星际争霸
php 删除记录实现代码
2009/03/12 PHP
php正则表达式基本知识与应用详解【经典教程】
2017/04/17 PHP
js每次Title显示不同的名言
2008/09/25 Javascript
JavaScript中Object和Function的关系小结
2009/09/26 Javascript
JQuery each()嵌套使用小结
2014/04/18 Javascript
javascript结合CSS实现苹果开关按钮特效
2015/04/07 Javascript
详细分析JavaScript变量类型
2015/07/08 Javascript
jQuery使用$.ajax进行即时验证实例详解
2015/12/11 Javascript
使用node+vue.js实现SPA应用
2016/01/28 Javascript
超实用的JavaScript代码段 附使用方法
2016/05/22 Javascript
Node.js配合node-http-proxy解决本地开发ajax跨域问题
2016/08/31 Javascript
简单谈谈gulp-changed插件
2017/02/21 Javascript
jQuery Validate 校验多个相同name的方法
2017/05/18 jQuery
Angular 表单控件示例代码
2017/06/26 Javascript
vue select组件的使用与禁用实现代码
2018/04/10 Javascript
详解vue-loader在项目中是如何配置的
2018/06/04 Javascript
Vue 实现拖动滑块验证功能(只有css+js没有后台验证步骤)
2018/08/24 Javascript
vue解决一个方法同时发送多个请求的问题
2018/09/25 Javascript
Vue中登录验证成功后保存token,并每次请求携带并验证token操作
2020/09/08 Javascript
Python微信库:itchat的用法详解
2017/08/14 Python
python2.7读取文件夹下所有文件名称及内容的方法
2018/02/24 Python
python 剪切移动文件的实现代码
2018/08/02 Python
使用python生成杨辉三角形的示例代码
2018/08/29 Python
信号生成及DFT的python实现方式
2020/02/25 Python
Python如何用filter函数筛选数据
2020/03/05 Python
使用Python爬取弹出窗口信息的实例
2020/03/14 Python
解决pip安装tensorflow中出现的no module named tensorflow.python 问题方法
2021/02/20 Python
乡镇务虚会发言材料
2014/10/20 职场文书
2014年小学校长工作总结
2014/12/08 职场文书
2015年七夕情人节感言
2015/08/03 职场文书
决心书格式范文
2015/09/23 职场文书
如何使用分区处理MySQL的亿级数据优化
2021/06/18 MySQL
springboot利用redis、Redisson处理并发问题的操作
2021/06/18 Java/Android
数据分析数据库ClickHouse在大数据领域应用实践
2022/04/03 MySQL
V Rising 服务器搭建图文教程
2022/06/16 Servers