灏天阁

vue3.2/Vite/Ts67: 收集新增SKU数据

· Yin灏

目录结构

└─src
    ├─api
    │  └─product
    │      └─spu
    │          ├─index.ts
    │          └─type.ts
    └─views
        └─product
            └─spu
                └─skuform.vue

新增接口

src/api/product/spu/index.ts

//...
import type { SkuData } from "./type";
//...
enum API {
  ADDSKU_URL = "/admin/product/saveSkuInfo",
}
//...
export const reqAddSku = (data: SkuData) =>
  request.post<any, any>(API.ADDSKU_URL, data);

定义接口数据的 TS 类型

src/api/product/spu/type.ts

export interface Attr {
  attrId: string | number;
  valueId: string | number;
}
export interface SaleAttr {
  saleAttrId: string | number;
  saleAttrValueId: string | number;
}
//...
export interface SkuData {
  category3Id: string | number;
  spuId: string | number;
  tmId: string | number;
  skuName: string;
  price: string | number;
  weight: string | number;
  skuDesc: string;
  skuAttrValueList?: Attr[];
  skuSaleAttrValueList?: SaleAttr[];
  skuDefaultImg: string;
}

收集新增 SKU 数据

src/views/product/spu/skuform.vue

<template>
  <el-form label-width="100px">
    <el-form-item label="SKU名称">
      <el-input placeholder="SKU名称" v-model="skuParams.skuName"></el-input>
    </el-form-item>
    <el-form-item label="价格(元)">
      <el-input
        placeholder="价格(元)"
        type="number"
        v-model="skuParams.price"
      ></el-input>
    </el-form-item>
    <el-form-item label="重量(g)">
      <el-input
        placeholder="重量(g)"
        type="number"
        v-model="skuParams.weight"
      ></el-input>
    </el-form-item>
    <el-form-item label="SKU描述">
      <el-input
        placeholder="SKU描述"
        type="textarea"
        v-model="skuParams.skuDesc"
      ></el-input>
    </el-form-item>
    <!-- 平台属性 -->
    <el-form-item label="平台属性">
      <el-form :inline="true">
        <el-form-item
          v-for="(item, index) in attrArr"
          :key="item.id"
          :label="item.attrName"
        >
          <el-select v-model="item.attrIdAndValue">
            <el-option
              v-for="(item1, index) in item.attrValueList"
              :key="item1.id"
              :label="item1.valueName"
              :value="`${item.id}:${item1.id}`"
            ></el-option>
          </el-select>
        </el-form-item>
      </el-form>
    </el-form-item>
    <el-form-item label="销售属性">
      <el-form :inline="true">
        <el-form-item
          v-for="(item, index) in saleArr"
          :key="item.id"
          :label="item.saleAttrName"
        >
          <el-select v-model="item.saleIdAndValueId">
            <el-option
              v-for="(item1, index) in item.spuSaleAttrValueList"
              :key="item1.id"
              :label="item1.saleAttrValueName"
              :value="`${item.id}:${item1.id}`"
            ></el-option>
          </el-select>
        </el-form-item>
      </el-form>
    </el-form-item>
    <el-form-item label="图片名称">
      <el-table :data="imgArr" ref="table">
        <el-table-column
          type="selection"
          width="80px"
          align="center"
        ></el-table-column>
        <el-table-column label="图片">
          <template #="{row}">
            <img :src="row.imgUrl" widht="100" height="100" />
          </template>
        </el-table-column>
        <el-table-column label="名称" prop="imgName"></el-table-column>
        <el-table-column label="操作">
          <template #="{row}">
            <el-button type="primary" size="small" @click="handler(row)"
              >设置默认</el-button
            >
          </template>
        </el-table-column>
      </el-table>
    </el-form-item>
    <!-- 按钮 -->
    <el-form-item>
      <el-button type="primary" size="small" @click="save">保存</el-button>
      <el-button type="primary" size="small" @click="cancel">取消</el-button>
    </el-form-item>
  </el-form>
</template>
<script setup lang="ts">
  import { ref } from "vue";
  import { reqAttr } from "@/api/product/attr";
  import {
    reqSpuImageList,
    reqSpuHasSaleAttr,
    reqAddSku,
  } from "@/api/product/spu";
  import type { SkuData } from "@/api/product/spu/type";

  let $emit = defineEmits(["changeScene"]);

  let attrArr = ref<any>([]);
  let saleArr = ref<any>([]);
  let imgArr = ref<any>([]);

  let table = ref<any>([]);

  let skuParams = reactive<SkuData>({
    category3Id: "",
    spuId: "",
    tmId: "",
    skuName: "",
    price: "",
    weight: "",
    skuDesc: "",
    skuAttrValueList: [],
    skuSaleAttrValueList: [],
    skuDefaultImg: "",
  });

  const cancel = () => {
    $emit("changeScene", {
      flag: 0,
      params: "",
    });
  };

  const save = async () => {
    skuParams.skuAttrValueList = attrArr.value.reduce(
      (prev: any, next: any) => {
        if (next.attrIdAndValueId) {
          let [attrId, valueId] = next.attrIdAndValueId.split(":");
          prev.push({
            attrId,
            valueId,
          });
        }
        return prev;
      },
      []
    );
    skuParams.skuSaleAttrValueList = saleArr.value.reduce(
      (prev: any, next: any) => {
        if (next.saleIdAndValueId) {
          let [saleAttrId, saleAttrValueId] = next.saleIdAndValueId.split(":");
          prev.push({
            saleAttrId,
            saleAttrValueId,
          });
        }
        return prev;
      },
      []
    );
    const result: any = await reqAddSku(skuParams);
    if (result.code === 200) {
      ElMessage({
        type: "success",
        message: "添加SKU成功",
      });
      $emit("changeScene", {
        flag: 0,
        params: "",
      });
    } else {
      ElMessage({
        type: "error",
        message: "添加SKU失败",
      });
    }
  };

  const initSkuData = async (
    c1Id: number | string,
    c2Id: number | string,
    spu: any
  ) => {
    // 收集数据
    skuParams.category3Id = spu.category3Id;
    skuParams.spuId = spu.id;
    skuParams.tmId = spu.tmId;
    const result: any = await reqAttr(c1Id, c2Id, spu.category3Id);
    const result1: any = await reqSpuHasSaleAttr(spu.id);
    const result2: any = await reqSpuImageList(spu.id);
    attrArr.value = result.data;
    saleArr.value = result1.data;
    imgArr.value = result2.data;
  };

  const handler = (row: any) => {
    imgArr.value.forEach((item: any) => {
      table.value.toggleRowSelection(row, false);
    });
    table.value.toggleRowSelection(row, true);
    skuParams.skuDefaultImg = row.imgUrl;
  };

  defineExpose({
    initSkuData,
  });
</script>

- Book Lists -