vue实现商城上货组件简易版


Posted in Javascript onNovember 27, 2017

本文实例为大家分享了vue实现商城上货组件的具体代码,供大家参考,具体内容如下

0、结果放前面

点击查看效果

带脚手架的源码

加个Star后,fork下来。

然后在控制台,先输入npm install安装依赖,再输入npm run dev运行查看效果

1、先列需求

一切开发都是基于需求做的,所以需求先行,根据需求设计功能。

需求如下:

  • 上货商品有多个属性类别;(例如:颜色、尺寸、型号)
  • 每个类别有多个子属性;(例如:白色、绿色、金色)
  • 每个商品必然具备每个类别的其中一个子属性;
  • 除此之外还有额外属性,如【库存】、【描述】、【价格】等,每个都有;
  • 要求属性类别可以无限添加;
  • 要求每个属性类别下面的子属性可以无限添加;
  • 最后输出所有组合,以及他们每个组合的额外属性;

例如:

  • 颜色(白色,金色),尺寸(41,42);
  • 那么一共有四种组合:(白色,41),(白色,42),(金色,41),(金色,42);
  • 然后给每个组合加上价格、数量等属性,最后用JSON格式输出;

例如输出以下结果:

[
 {
  '颜色': '白色',
  '尺寸': '10',
  'price': '0',
  'count': '1'
 },
 {
  '颜色': '白色',
  '尺寸': '20',
  'price': '0',
  'count': '1'
 },
 {
  '颜色': '绿色',
  '尺寸': '10',
  'price': '0',
  'count': '1'
 },
 {
  '颜色': '绿色',
  '尺寸': '20',
  'price': '0',
  'count': '1'
 }
]

2、思路

由于无限可扩展的特性,因此模块分拆为两部分:

负责支持无限添加功能(包括类别和类别的属性);
根据已添加的类别和属性,组合出列表,并将列表展示或输出;

3、代码如下

由于功能类似,因此没有写删除、修改功能,但思路跟添加是一致的。

点击查看效果

带脚手架的源码

加个Star后,fork下来。

然后在控制台,先输入npm install安装依赖,再输入npm run dev运行查看效果

详细请参考注释:

/**
* Created by 王冬 on 2017/11/14.
* QQ: 20004604
* weChat: qq20004604
*/

<template>
 <div>
  <button @click='getList'>输出结果</button>
  <div>
   输入分类名,然后点击【确认】按钮添加新的分类
   <input type='text' v-model='category'>
   <button @click='addCategory'>确认</button>
  </div>

  <template v-for='i in categoryList'>
   <div class='category'>
    <p>类别:{{i.name}}</p>
    <div>属性:
     <p>新增属性名:<input type='text' v-model='i.newPropertyName'>
      <button @click='addToPropertyList(i)'>点击添加</button>
     </p>
     <div class='property-list'>
      <template v-for='pro in i.propertyList'>
       <div class='property'>{{pro}}</div>
      </template>
      <div class='clearfloat'></div>
     </div>
    </div>
   </div>
  </template>

  <p>以下是展示列表</p>
  <div class='show-list'>
   <table>
    <tr>
     <td v-for='i in categoryList'>
      {{i.name}}
     </td>
     <td>价格</td>
     <td>数量</td>
    </tr>
    <tr v-for='(val,key) in showList'>
     <td v-for='i in categoryList'>
      {{val[i.name]}}
     </td>
     <td>
      <input type='text' v-model="val['price']">
     </td>
     <td>
      <input type='text' v-model="val['count']">
     </td>
    </tr>
   </table>
  </div>
 </div>
</template>
<style scoped>
 .category {
  border: 1px solid #333;
 }

 .property {
  float: left;
  border: 1px solid #333;
  display: inline-block;
 }

 table {
  border-collapse: collapse;
 }

 th, td {
  border: 1px solid #000;
 }

 /*--清除浮动--*/
 .clearfloat {
  width: 0;
  clear: both;
  overflow: hidden;
  visibility: hidden;
 }
</style>
<script>
 export default {
  data () {
   return {
    // 要添加的新类别的名字
    category: '',
    // 类别列表
    categoryList: [
     {
      // 类别名
      name: '颜色',
      // 类别属性列表
      propertyList: ['白色', '绿色']
     },
     {
      name: '尺寸',
      propertyList: ['10', '20']
     },
     {
      name: '类型',
      propertyList: ['衣服', '裤子']
     }
    ]
   }
  },
  computed: {
   // 输出列表
   showList () {
    let arr = []
    this.toGet(arr, {}, 0, this.categoryList.length)
    return arr
   }
  },
  methods: {
   // 添加一个新的类别
   addCategory () {
    // 创建新类别
    let obj = {
     name: this.category,
     propertyList: [],
     newPropertyName: ''
    }
    // 添加到类别列表中
    this.categoryList.push(obj)
    this.category = ''
   },
   // 向类别添加属性
   addToPropertyList (category) {
    // 在该类别的属性里列表里添加新的属性
    category.propertyList.push(category.newPropertyName)
    category.newPropertyName = ''
   },
   // 递归
   getList () {
    console.log(this.showList)
    return this.showList
   },
   // 将数据组合成列表,利用递归的特性
   toGet (arr, obj, currentIndex, maxLength) {
    if (currentIndex >= maxLength) {
     return
    }
    this.categoryList[currentIndex].propertyList.forEach(item => {
     // 在组合到最后一个之前,不停的往模板对象上添加属性
     obj[this.categoryList[currentIndex].name] = item
     if (currentIndex === maxLength - 1) {
      // 组合到最后一个后,创建一个新的对象,然后放置入列表中
      let result = Object.assign({}, obj)
      result.price = '0'
      result.count = '1'
      arr.push(result)
     } else {
      this.toGet(arr, obj, currentIndex + 1, maxLength)
     }
    })
   }
  }
 }
</script>

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

Javascript 相关文章推荐
javascript 写类方式之一
Jul 05 Javascript
不安全的常用的js写法
Sep 15 Javascript
JavaScript关于select的相关操作说明
Jan 13 Javascript
JS俄罗斯方块,包含完整的设计理念
Dec 11 Javascript
jQuery之DOM对象和jQuery对象的转换与区别分析
Jan 08 Javascript
用js判断是否为360浏览器的实现代码
Jan 15 Javascript
angular中使用路由和$location切换视图
Jan 23 Javascript
AngularJS中的Directive自定义一个表格
Jan 25 Javascript
jQuery使用each方法与for语句遍历数组示例
Jun 16 Javascript
jQuery焦点图左右转换效果
Dec 12 Javascript
vue2.0结合DataTable插件实现表格动态刷新的方法详解
Mar 17 Javascript
详解从react转职到vue开发的项目准备
Jan 14 Javascript
修改UA在PC中访问只能在微信中打开的链接方法
Nov 27 #Javascript
Vue的移动端多图上传插件vue-easy-uploader的示例代码
Nov 27 #Javascript
vue实现商城购物车功能
Nov 27 #Javascript
Vim快速合并行及vim 将文件所有行合并到一行
Nov 27 #Javascript
详解利用Angular实现多团队模块化SPA开发框架
Nov 27 #Javascript
JavaScript实现修改伪类样式
Nov 27 #Javascript
Vue.js搭建移动端购物车界面
Jun 28 #Javascript
You might like
PHP自动更新新闻DIY
2006/10/09 PHP
php中的实现trim函数代码
2007/03/19 PHP
用PHP实现读取和编写XML DOM代码
2010/04/07 PHP
深入分析php之面向对象
2013/05/15 PHP
Yii框架关联查询with用法分析
2014/12/02 PHP
php实现的错误处理封装类实例
2017/06/20 PHP
jquery实现图片灯箱明暗的遮罩效果
2013/11/15 Javascript
JQuery做的一个简单的点灯游戏分享
2014/07/16 Javascript
JavaScript AJAX之惰性载入函数
2014/08/27 Javascript
node.js中的Socket.IO使用实例
2014/11/04 Javascript
javascript手工制作悬浮菜单
2015/02/12 Javascript
javascript生成随机数方法汇总
2015/11/12 Javascript
NodeJs——入门必看攻略
2016/06/27 NodeJs
通过JS获取Request.QueryString()参数的值实现方法
2016/09/27 Javascript
原生JS实现几个常用DOM操作API实例
2017/01/19 Javascript
详解vue中使用express+fetch获取本地json文件
2017/10/10 Javascript
原生JavaScrpit中异步请求Ajax实现方法
2017/11/03 Javascript
nodejs 最新版安装npm 的使用详解
2018/01/18 NodeJs
浅析vue给不同环境配置不同打包命令
2018/08/17 Javascript
layui框架table 数据表格的方法级渲染详解
2018/08/19 Javascript
vue登录以及权限验证相关的实现
2019/10/25 Javascript
JS使用setInterval计时器实现挑战10秒
2020/11/08 Javascript
Python第三方Window模块文件的几种安装方法
2018/11/22 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
Python partial函数原理及用法解析
2019/12/11 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
根据tensor的名字获取变量的值方式
2020/01/04 Python
python2.7使用scapy发送syn实例
2020/05/05 Python
Python分析微信好友性别比例和省份城市分布比例的方法示例【基于itchat模块】
2020/05/29 Python
Pyside2中嵌入Matplotlib的绘图的实现
2021/02/22 Python
法国床上用品商店:La Compagnie du lit
2019/12/26 全球购物
论文评语大全
2014/04/29 职场文书
爱心捐书活动总结
2014/07/05 职场文书
电力安全学习心得体会
2016/01/18 职场文书
创业计划书之溜冰场
2019/10/25 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书