Sku 商品购买组件

使用指南

  1. import { Sku } from 'vant';
  2. Vue.use(Sku);

代码演示

基础用法

  1. <van-sku
  2. v-model="showBase"
  3. :sku="sku"
  4. :goods="goods"
  5. :goods-id="goodsId"
  6. :hide-stock="sku.hide_stock"
  7. :quota="quota"
  8. :quota-used="quotaUsed"
  9. :reset-stepper-on-hide="resetStepperOnHide"
  10. :reset-selected-sku-on-hide="resetSelectedSkuOnHide"
  11. :close-on-click-overlay="closeOnClickOverlay"
  12. :disable-stepper-input="disableStepperInput"
  13. :message-config="messageConfig"
  14. @buy-clicked="onBuyClicked"
  15. @add-cart="onAddCartClicked"
  16. />

自定义步进器相关配置

  1. <van-sku
  2. v-model="showBase"
  3. :sku="sku"
  4. :goods="goods"
  5. :goods-id="goodsId"
  6. :hide-stock="sku.hide_stock"
  7. :quota="quota"
  8. :quota-used="quotaUsed"
  9. :custom-stepper-config="customStepperConfig"
  10. @buy-clicked="onBuyClicked"
  11. @add-cart="onAddCartClicked"
  12. />

高级用法

  1. <van-sku
  2. v-model="showCustomAction"
  3. stepper-title="我要买"
  4. :sku="sku"
  5. :goods="goods"
  6. :goods-id="goodsId"
  7. :hide-stock="sku.hide_stock"
  8. :quota="quota"
  9. :quota-used="quotaUsed"
  10. show-add-cart-btn
  11. reset-stepper-on-hide
  12. :initial-sku="initialSku"
  13. @buy-clicked="onBuyClicked"
  14. @add-cart="onAddCartClicked"
  15. >
  16. <!-- 自定义 sku-header-price -->
  17. <template slot="sku-header-price" slot-scope="props">
  18. <div class="van-sku__goods-price">
  19. <span class="van-sku__price-symbol"></span><span class="van-sku__price-num">{{ props.price }}</span>
  20. </div>
  21. </template>
  22. <!-- 自定义 sku actions -->
  23. <template slot="sku-actions" slot-scope="props">
  24. <div class="van-sku-actions">
  25. <van-button bottom-action @click="onPointClicked">积分兑换</van-button>
  26. <!-- 直接触发 sku 内部事件,通过内部事件执行 onBuyClicked 回调 -->
  27. <van-button type="primary" bottom-action @click="props.skuEventBus.- emit('sku:buy')">买买买</van-button>
  28. </div>
  29. </template>
  30. </van-sku>

API

参数 说明 类型 默认值
v-model 是否显示sku Boolean false
sku 商品sku数据 Object -
goods 商品信息 Object -
goods-id 商品id String Number -
hide-stock 是否显示商品剩余库存 Boolean false
show-add-cart-btn 是否显示加入购物车按钮 Boolean true
quota 限购数(0表示不限购) Number 0
quota-used 已经购买过的数量 Number 0
reset-stepper-on-hide 窗口隐藏时重置选择的商品数量 Boolean false
reset-selected-sku-on-hide 窗口隐藏时重置已选择的sku Boolean false
disable-stepper-input 是否禁用sku中stepper的input框 Boolean false
close-on-click-overlay 点击popup的overlay后是否关闭弹窗 Boolean false
stepper-title 数量选择组件左侧文案 String 购买数量
custom-stepper-config 步进器相关自定义配置 Object {}
message-config 留言相关配置 Object {}
get-container 指定挂载的 HTML 节点 () => HTMLElement -

Event

事件名 说明 参数
add-cart 点击添加购物车回调 skuData: Object
buy-clicked 点击购买回调 skuData: Object

方法

通过 ref 可以获取到 sku 实例并调用实例方法

方法名 参数 返回值 介绍
getSkuData - skuData 获取当前 skuData

Slot

Sku 组件默认划分好了若干区块,这些区块都定义成了 slot,可以按需进行替换。区块顺序见下表:

名称 说明
sku-header 商品信息展示区,包含商品图片、名称、价格等信息
sku-header-price 自定义sku头部价格展示
sku-body-top sku展示区上方的slot,无默认展示内容,按需使用
sku-group 商品sku展示区
extra-sku-group 额外商品sku展示区,一般用不到
sku-stepper 商品数量选择区
sku-messages 商品留言区
sku-actions 操作按钮区

数据结构

sku对象结构

  1. sku: {
  2. // 所有sku规格类目与其值的从属关系,比如商品有颜色和尺码两大类规格,颜色下面又有红色和蓝色两个规格值。
  3. // 可以理解为一个商品可以有多个规格类目,一个规格类目下可以有多个规格值。
  4. tree: [
  5. {
  6. k: '颜色', // skuKeyName:规格类目名称
  7. v: [
  8. {
  9. id: '30349', // skuValueId:规格值 id
  10. name: '红色', // skuValueName:规格值名称
  11. imgUrl: 'https://img.yzcdn.cn/1.jpg' // 规格类目图片,只有第一个规格类目可以定义图片
  12. },
  13. {
  14. id: '1215',
  15. name: '蓝色',
  16. imgUrl: 'https://img.yzcdn.cn/2.jpg'
  17. }
  18. ],
  19. k_s: 's1' // skuKeyStr:sku 组合列表(下方 list)中当前类目对应的 key 值,value 值会是从属于当前类目的一个规格值 id
  20. }
  21. ],
  22. // 所有 sku 的组合列表,比如红色、M 码为一个 sku 组合,红色、S 码为另一个组合
  23. list: [
  24. {
  25. id: 2259, // skuId,下单时后端需要
  26. price: 100, // 价格(单位分)
  27. s1: '1215', // 规格类目 k_s 为 s1 的对应规格值 id
  28. s2: '1193', // 规格类目 k_s 为 s2 的对应规格值 id
  29. s3: '0', // 最多包含3个规格值,为0表示不存在该规格
  30. stock_num: 110 // 当前 sku 组合对应的库存
  31. }
  32. ],
  33. price: '1.00', // 默认价格(单位元)
  34. stock_num: 227, // 商品总库存
  35. collection_id: 2261, // 无规格商品 skuId 取 collection_id,否则取所选 sku 组合对应的 id
  36. none_sku: false, // 是否无规格商品
  37. messages: [
  38. {
  39. // 商品留言
  40. datetime: '0', // 留言类型为 time 时,是否含日期。'1' 表示包含
  41. multiple: '0', // 留言类型为 text 时,是否多行文本。'1' 表示多行
  42. name: '留言', // 留言名称
  43. type: 'text', // 留言类型,可选: id_no(身份证), text, tel, date, time, email
  44. required: '1' // 是否必填 '1' 表示必填
  45. }
  46. ],
  47. hide_stock: false // 是否隐藏剩余库存
  48. }

goods 对象结构

  1. goods: {
  2. // 商品标题
  3. title: '测试商品',
  4. // 默认商品 sku 缩略图
  5. picture: 'https://img.yzcdn.cn/1.jpg'
  6. }

customStepperConfig 对象结构

  1. customStepperConfig: {
  2. // 自定义限购文案
  3. quotaText: '每次限购xxx件',
  4. // 自定义步进器超过限制时的回调
  5. handleOverLimit: (data) => {
  6. const { action, limitType, quota, quotaUsed } = data;
  7. if (action === 'minus') {
  8. Toast('至少选择一件商品');
  9. } else if (action === 'plus') {
  10. // const { LIMIT_TYPE } = Sku.skuConstants;
  11. if (limitType === LIMIT_TYPE.QUOTA_LIMIT) {
  12. let msg = `单次限购- {quota}件`;
  13. if (quotaUsed > 0) msg += `,您已购买- {quotaUsed}`;
  14. Toast(msg);
  15. } else {
  16. Toast('库存不够了~~');
  17. }
  18. }
  19. }
  20. }

messageConfig Data Structure

  1. messageConfig: {
  2. // 图片上传回调,需要返回一个promise,promise正确执行的结果需要是一个图片url
  3. uploadImg: () => {
  4. return new Promise((resolve) => {
  5. setTimeout(() => resolve('https://img.yzcdn.cn/upload_files/2017/02/21/FjKTOxjVgnUuPmHJRdunvYky9OHP.jpg!100x100.jpg'), 1000);
  6. });
  7. },
  8. // 最大上传体积 (MB)
  9. uploadMaxSize: 3,
  10. // placehold配置
  11. placeholderMap: {
  12. text: 'xxx',
  13. tel: 'xxx',
  14. ...
  15. }
  16. }

添加购物车和点击购买回调函数接收的 skuData 对象结构

  1. skuData: {
  2. // 商品 id
  3. goodsId: '946755',
  4. // 留言信息
  5. messages: {
  6. message_0: '12',
  7. message_1: ''
  8. },
  9. // 另一种格式的留言,key 不同
  10. cartMessages: {
  11. '留言1': 'xxxx'
  12. },
  13. // 选择的商品数量
  14. selectedNum: 1,
  15. // 选择的 sku 组合
  16. selectedSkuComb: {
  17. id: 2257,
  18. price: 100,
  19. s1: '30349',
  20. s2: '1193',
  21. s3: '0',
  22. stock_num: 111
  23. }
  24. }

原文:

https://youzan.github.io/vant/#/zh-CN/sku