1.0.19 • Published 1 year ago

vant-sku v1.0.19

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

Sku 商品规格

tip: 删除了messageConfig

全局注册组件

import { createApp } from 'vue';
import VanSku from 'vant-sku';

const app = createApp();
app.use(VanSku);

按需引入

import VanSku from 'vant-sku';
import 'vant-sku/dist/index.css'

代码演示

查看更多属性配置 请参照:vant2.x sku

基础用法

<van-sku
  v-model="show"
  :sku="sku"
  :goods="goods"
  :goods-id="goodsId"
  :quota="quota"
  :quota-used="quotaUsed"
  :hide-stock="sku.hide_stock"
 
  @buy-clicked="onBuyClicked"
  @add-cart="onAddCartClicked"
/>
import { ref } from 'vue';

export default {
  setup() {
    const show = ref(false);
    return { 
      show,
       sku: {
        // 数据结构见下方文档
      },
      goods: {
        // 数据结构见下方文档
      },
    };
  },
};

自定义步进器

<van-sku
  v-model="show"
  :sku="sku"
  :goods="goods"
  :goods-id="goodsId"
  :quota="quota"
  :quota-used="quotaUsed"
  :hide-stock="sku.hide_stock"
  :custom-stepper-config="customStepperConfig"
  @buy-clicked="onBuyClicked"
  @add-cart="onAddCartClicked"
/>

通过插槽定制

<van-sku
  v-model="show"
  stepper-title="我要买"
  :sku="sku"
  :goods="goods"
  :goods-id="goodsId"
  :quota="quota"
  :quota-used="quotaUsed"
  :hide-stock="sku.hide_stock"
  show-add-cart-btn
  reset-stepper-on-hide
  :initial-sku="initialSku"
  @buy-clicked="onBuyClicked"
  @add-cart="onAddCartClicked"
>
  <!-- 自定义 sku-header-price -->
  <template #sku-header-price="props">
    <div class="van-sku__goods-price">
      <span class="van-sku__price-symbol">¥</span
      ><span class="van-sku__price-num">{{ props.price }}</span>
    </div>
  </template>

  <!-- 自定义 sku actions -->
  <template #sku-actions="props">
    <div class="van-sku-actions">
      <van-button square size="large" type="warning" @click="onPointClicked">
        积分兑换
      </van-button>
      <!-- 直接触发 sku 内部事件,通过内部事件执行 onBuyClicked 回调 -->
      <van-button
        square
        size="large"
        type="danger"
        @click="props.skuEventBus.$emit('sku:buy')"
      >
        买买买
      </van-button>
    </div>
  </template>
</van-sku>

API

Props

参数说明类型默认值
v-model是否显示商品规格弹窗booleanfalse
sku商品 sku 数据object-
goods商品信息object-
goods-id商品 idnumber | string-
price-tag显示在价格后面的标签string-
hide-stock是否显示商品剩余库存booleanfalse
hide-quota-text是否显示限购提示booleanfalse
hide-selected-text是否隐藏已选提示booleanfalse
stock-threshold库存阈值。低于这个值会把库存数高亮显示boolean50
show-add-cart-btn是否显示加入购物车按钮booleantrue
buy-text购买按钮文字string立即购买
add-cart-text加入购物车按钮文字string加入购物车
quota限购数,0 表示不限购number0
quota-used已经购买过的数量number0
reset-stepper-on-hide隐藏时重置选择的商品数量booleanfalse
reset-selected-sku-on-hide隐藏时重置已选择的 skubooleanfalse
disable-stepper-input是否禁用步进器输入booleanfalse
close-on-click-overlay是否在点击遮罩层后关闭booleantrue
stepper-title数量选择组件左侧文案string购买数量
custom-stepper-config步进器相关自定义配置object{}
message-config留言相关配置object{}
get-container指定挂载的节点,用法示例string | () => Element-
initial-sku默认选中的 sku,具体参考高级用法object{}
show-soldout-sku是否展示售罄的 sku,默认展示并置灰booleantrue
disable-soldout-sku v2.11.3是否禁用售罄的 skubooleantrue
safe-area-inset-bottom是否开启底部安全区适配booleantrue
start-sale-num起售数量number1
properties商品属性array-
preview-on-click-image v2.5.2是否在点击商品图片时自动预览booleantrue
show-header-image v2.9.0是否展示头部图片booleantrue
lazy-load v2.9.0是否开启图片懒加载,须配合 Lazyload 组件使用booleanfalse

Events

事件名说明回调参数
add-cart点击添加购物车回调skuData: object
buy-clicked点击购买回调skuData: object
stepper-change购买数量变化时触发value: number
sku-selected切换规格类目时触发{ skuValue, selectedSku, selectedSkuComb }
sku-prop-selected切换商品属性时触发{ propValue, selectedProp, selectedSkuComb }
open-preview打开商品图片预览时触发data: object
close-preview关闭商品图片预览时触发data: object
sku-reset v2.8.1规格和属性被重置时触发{ selectedSku, selectedProp, selectedSkuComb }

方法

通过 ref 可以获取到 Sku 实例并调用实例方法,详见组件实例方法

方法名说明参数返回值
getSkuData获取当前 skuData-skuData
resetSelectedSku重置选中规格到初始状态--

Slots

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

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

sku 对象结构

sku: {
  // 所有sku规格类目与其值的从属关系,比如商品有颜色和尺码两大类规格,颜色下面又有红色和蓝色两个规格值。
  // 可以理解为一个商品可以有多个规格类目,一个规格类目下可以有多个规格值。
  tree: [
    {
      k: '颜色', // skuKeyName:规格类目名称
      k_s: 's1', // skuKeyStr:sku 组合列表(下方 list)中当前类目对应的 key 值,value 值会是从属于当前类目的一个规格值 id
      v: [
        {
          id: '1', // skuValueId:规格值 id
          name: '红色', // skuValueName:规格值名称
          imgUrl: 'https://img01.yzcdn.cn/1.jpg', // 规格类目图片,只有第一个规格类目可以定义图片
          previewImgUrl: 'https://img01.yzcdn.cn/1p.jpg', // 用于预览显示的规格类目图片
        },
        {
          id: '1',
          name: '蓝色',
          imgUrl: 'https://img01.yzcdn.cn/2.jpg',
          previewImgUrl: 'https://img01.yzcdn.cn/2p.jpg',
        }
      ],
      largeImageMode: true, //  是否展示大图模式
    }
  ],
  // 所有 sku 的组合列表,比如红色、M 码为一个 sku 组合,红色、S 码为另一个组合
  list: [
    {
      id: 2259, // skuId
      s1: '1', // 规格类目 k_s 为 s1 的对应规格值 id
      s2: '1', // 规格类目 k_s 为 s2 的对应规格值 id
      price: 100, // 价格(单位分)
      stock_num: 110 // 当前 sku 组合对应的库存
    }
  ],
  price: '1.00', // 默认价格(单位元)
  stock_num: 227, // 商品总库存
  collection_id: 2261, // 无规格商品 skuId 取 collection_id,否则取所选 sku 组合对应的 id
  none_sku: false, // 是否无规格商品
  messages: [
    {
      // 商品留言
      datetime: '0', // 留言类型为 time 时,是否含日期。'1' 表示包含
      multiple: '0', // 留言类型为 text 时,是否多行文本。'1' 表示多行
      name: '留言', // 留言名称
      type: 'text', // 留言类型,可选: id_no(身份证), text, tel, date, time, email
      required: '1', // 是否必填 '1' 表示必填
      placeholder: '', // 可选值,占位文本
      extraDesc: ''  // 可选值,附加描述文案
    }
  ],
  hide_stock: false // 是否隐藏剩余库存
}

properties 对象结构

[
  // 商品属性
  {
    k_id: 123, // 属性id
    k: '加料', // 属性名
    is_multiple: true, // 是否可多选
    v: [
      {
        id: 1222, // 属性值id
        name: '珍珠', // 属性值名
        price: 1, // 属性值加价
        text_status: 0, // 属性启用/禁用状态 0 - 禁用,1 - 启用
      },
      {
        id: 1223,
        name: '椰果',
        price: 1,
        text_status: 1,
      },
    ],
  },
];

initialSku 对象结构

{
  // 键:skuKeyStr(sku 组合列表中当前类目对应的 key 值)
  // 值:skuValueId(规格值 id)
  s1: '1',
  s2: '1',
  // 初始选中数量
  selectedNum: 3,
  // 初始选中的商品属性
  // 键:属性id
  // 值:属性值id列表
  selectedProp: {
    123: [1222]
  }
}

goods 对象结构

goods: {
  // 默认商品 sku 缩略图
  picture: 'https://img01.yzcdn.cn/1.jpg';
}

customStepperConfig 对象结构

customStepperConfig: {
  // 自定义限购文案
  quotaText: '每次限购xxx件',
  // 自定义步进器超过限制时的回调
  handleOverLimit: (data) => {
    const { action, limitType, quota, quotaUsed, startSaleNum } = data;

    if (action === 'minus') {
      Toast(startSaleNum > 1  ? `${startSaleNum}件起售` : '至少选择一件商品');
    } else if (action === 'plus') {
      // const { LIMIT_TYPE } = Sku.skuConstants;
      if (limitType === LIMIT_TYPE.QUOTA_LIMIT) {
        let msg = `单次限购${quota}件`;
        if (quotaUsed > 0) msg += `,你已购买${quotaUsed}`;
        Toast(msg);
      } else {
        Toast('库存不够了');
      }
    }
  },
  // 步进器变化的回调
  handleStepperChange: currentValue => {},
  // 库存
  stockNum: 1999,
  // 格式化库存
  stockFormatter: stockNum => {},
}

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

skuData: {
  // 商品 id
  goodsId: '946755',
  // 留言信息
  messages: {
    message_0: '12',
    message_1: ''
  },
  // 另一种格式的留言,key 不同
  cartMessages: {
    '留言1': 'xxxx'
  },
  // 选择的商品数量
  selectedNum: 1,
  // 选择的 sku 组合
  selectedSkuComb: {
    id: 2257,
    price: 100,
    s1: '30349',
    s2: '1193',
    s3: '0',
    stock_num: 111,
    properties: [
      {
        k_id: 123,
        k: '加料',
        is_multiple: true,
        v: [
          {
            id: 1223,
            name: '椰果',
            price: 1
          }
        ]
      }
    ],
    property_price: 1
  },
}

样式变量

组件提供了下列 Less 变量,可用于自定义样式,使用方法请参考主题定制

名称默认值描述
@sku-item-background-color@background-color-
@sku-icon-gray-color@gray-4-
@sku-upload-mask-colorrgba(50, 50, 51, 0.8)-

Donate

If you find this project useful, you can buy author a glass of coffee : tropical_drink: 如果你觉得这个项目帮助到了你,你可以帮作者买一杯咖啡鼓励 :tropical_drink:

Wechat

Alipay

1.0.19

1 year ago

1.0.2

1 year ago

1.0.18

1 year ago

1.0.1

1 year ago

1.0.17

1 year ago

1.0.0

1 year ago

1.0.16

1 year ago

1.0.6

1 year ago

1.0.5

1 year ago

1.0.4

1 year ago

1.0.3

1 year ago

0.0.2

3 years ago

1.0.11

1 year ago

1.0.15

1 year ago

0.0.1

3 years ago