vue3-实战-07-管理后台-属性管理模块开发

news2024/11/17 14:33:53

目录

1-需求原型分析

2-三级分类全局组件封装

2.1-三级分类组件请求接口和数据类型封装

2.2-组件获取数据渲染数据

3-属性管理列表开发

3.1-请求接口和数据类型封装

3.2-获取数据渲染数据

4-新增编辑属性

4.1-需求原型分析

4.2-新增编辑接口封装和数据类型定义

4.3-新增属性开发

5-删除属性


1-需求原型分析

      原型分为上下两部分,上面是三级分类数据,下面是属性数据,使用的都是el-card组件。因为三级分类在其他地方使用到,我们可以将三级分类注册为全局组件。下部分跟品牌管理列表类似,el-card里面有el-table组件。当我们必须三级分类全部选择后,我们才展示下面的table数据。

2-三级分类全局组件封装

       我们将三级分类封装为全局组件。页面加载时候,我们需要获取一级分类数据,如果选中了一级分类,我们才能获取二级分类数据,选中了二级分类,才能获取三级分类的数据。选中三级分类数据,我们才展示下面的属性列表和添加属性按钮。

2.1-三级分类组件请求接口和数据类型封装

       我们先进行三级分类的接口封装和数据类型定义。因为我们的数据不只是在当前自己的组件使用,还需要其他组件使用,所以我们请求数据需要存放在仓库中。这样方便属性管理的其他组件使用。

文件src\api\product\attr\index.ts定义相关接口

enum API {
  C1_URL = '/admin/product/getCategory1',//获取一级分类接口地址
  C2_URL = '/admin/product/getCategory2/',//获取二级分类接口地址
  C3_URL = '/admin/product/getCategory3/',//获取三级分类接口地址
  ATTR_URL = '/admin/product/attrInfoList/',//获取分类下已有的属性与属性值
}

//获取一级分类的接口方法
export const reqC1 = () => request.get<any, CategoryResponseData>(API.C1_URL)

//获取二级分类的接口方法
export const reqC2 = (category1Id: number | string) =>request.get<any, CategoryResponseData>(API.C2_URL + category1Id)

//获取二级分类的接口方法
export const reqC3 = (category2Id: number | string) => request.get<any,CategoryResponseData>(API.C3_URL + category2Id)

仓库文件src\store\modules\category.ts获取数据,存储数据:

//商品分类全局组件的小仓库
import { defineStore } from 'pinia'
import { reqC1, reqC2, reqC3 } from '@/api/product/attr'
import type { CategoryResponseData } from '@/api/product/attr/type'
import type { CategoryState } from './types/type'
const useCategoryStore = defineStore('Category', {
  state: (): CategoryState => {
    return {     
      c1Arr: [],//存储一级分类的数据     
      c1Id: '',//存储一级分类的ID     
      c2Arr: [],//存储对应一级分类下二级分类的数据     
      c2Id: '',//收集二级分类的ID     
      c3Arr: [],//存储三级分类的数据     
      c3Id: '',//存储三级分类的ID
    }
  },
  actions: {
    //获取一级分类的方法
    async getC1() {
      //发请求获取一级分类的数据
      const result: CategoryResponseData = await reqC1()
      if (result.code == 200) {
        this.c1Arr = result.data
      }
    },
    //获取二级分类的数据
    async getC2() {
      //获取对应一级分类的下二级分类的数据
      const result: CategoryResponseData = await reqC2(this.c1Id)
      if (result.code == 200) {
        this.c2Arr = result.data
      }
    },
    //获取三级分类的数据
    async getC3() {
      const result: CategoryResponseData = await reqC3(this.c2Id)
      if (result.code == 200) {
        this.c3Arr = result.data
      }
    },
  },
  getters: {},
})

export default useCategoryStore

2.2-组件获取数据渲染数据

      组件挂载的时候,我们就需要发送请求获取一级分类数据,当我们切换一级分类(一级分类发生变化之后),我们需要清空二级和三级分类数据,再次获取二级分类的数据,同理当我们切换二级分类(二级分类发生变化之后),我们需要清空三级分类数据,再次获取三级分类的数据。

页面结构,动态渲染数据:

 业务逻辑开发:

3-属性管理列表开发

       当我们选中三级分类的时候,我们需要向服务器发送请求或者三级分类下面的属性列表数据。此时我们可以在父组件中监听watch子组件(三级分类组件)中三级分类id是否有值,如果有值,需要重新发送请求,获取列表数据。

3.1-请求接口和数据类型封装

先根据接口文档封装接口和请求数据。
ATTR_URL = '/admin/product/attrInfoList/',//获取分类下已有的属性与属性值

//获取对应分类下已有的属性与属性值接口
export const reqAttr = (
category1Id: string | number,
category2Id: string | number,
category3Id: string | number,) =>request.get<any, AttrResponseData>(API.ATTR_URL + `${category1Id}/${category2Id}/${category3Id}`,)

3.2-获取数据渲染数据

当我们监听到三级分类id不为空时,我们就发送请求获取获取属性值列表数据。

       获取数据后,我们展示数据,一般没有特殊结构的数据展示,直接使用prop属性来展示,当我们需要构造我们的结构,我们必须使用插槽来展示数据。

4-新增编辑属性

4.1-需求原型分析

点击添加属性效果:

 点击编辑属性效果:

       当我们点击添加属性或者编辑的时候,我们需要将列表表格隐藏,并且三级分类组件上面的数据不需要disabled,切换到添加或者编辑属性的页面。当属性名称为空的时候,添加属性值按钮是disabled状态。

页面结构:上面一部分是个el-form里面有个el-input输入框;下面是一个el-table结构,其中属性值名称在input和div之间来回切换。

4.2-新增编辑接口封装和数据类型定义

 

4.3-新增属性开发

       当我们点击添加属性的时候,我们需要切换场景值,显示添加或者修改的结构,隐藏属性列表table结构。

 定义场景切换的变量,默认为0;定义新增属性的数据结构

 默认的场景是0,当没有选择三级分类的id时候,按钮不可用。

//添加属性按钮的回调
const addAttr = () => {
    //每一次点击的时候,先清空一下数据再收集数据
    Object.assign(attrParams, {
        attrName: "",//新增的属性的名字
        attrValueList: [//新增的属性值数组
        ],
        categoryId: categoryStore.c3Id,//三级分类的ID
        categoryLevel: 3,//代表的是三级分类
    })
    //切换为添加与修改属性的结构
    scene.value = 1;
}

主要难点:判断属性值名称在input和div之间切换,

<!-- 展示添加属性与修改数据的结构 -->
<el-form :inline="true">
	<el-form-item label="属性名称">
		<el-input placeholder="请你输入属性名称" v-model="attrParams.attrName"></el-input>
	</el-form-item>
</el-form>
<el-button @click="addAttrValue" :disabled="attrParams.attrName ? false : true" type="primary"
	size="default" icon="Plus">添加属性值</el-button>
<el-button type="primary" size="default" @click="cancel">取消</el-button>
<el-table border style="margin:10px 0px" :data="attrParams.attrValueList">
	<el-table-column label="序号" width="80px" type="index" align="center"></el-table-column>
	<el-table-column label="属性值名称">
		<!-- row:即为当前属性值对象 -->
		<template #="{ row, $index }">
			<el-input :ref="(vc: any) => inputArr[$index] = vc" v-if="row.flag" @blur="toLook(row, $index)"
				size="small" placeholder="请你输入属性值名称" v-model="row.valueName"></el-input>
			<div v-else @click="toEdit(row, $index)">{{ row.valueName }}</div>
		</template>
	</el-table-column>
	<el-table-column label="属性值操作">
		<template #="{ row, index }">
			<el-button type="primary" size="small" icon="Delete"
				@click="attrParams.attrValueList.splice(index, 1)"></el-button>
		</template>
	</el-table-column>
</el-table>
<el-button type="primary" size="default" @click="save"
	:disabled="attrParams.attrValueList.length > 0 ? false : true">保存</el-button>
<el-button type="primary" size="default" @click="cancel">取消</el-button>

当我们点击添加属性值按钮时候,我们需要在下面添加一行,优化焦点聚焦。

 当焦点离开的时候,触发blur的toLook方法,需要判读当前输入框是不是空值,有没有重复的属性值等逻辑。

 当点击这个div时,需要触发toEdit方法切换至input输入框形式。

当点击属性值操作删除按钮时,直接删除当前记录。

 点击取消按钮,直接切换场景值为0

       点击保存操作的时候,我们需要收集数据,请求服务端接口;都是采用v-model可以双向实时收集数据,不需要额外的处理。

 

//保存按钮的回调
const save = async () => {  
    let result: any = await reqAddOrUpdateAttr(attrParams);//发请求    
    if (result.code == 200) {//添加属性|修改已有的属性已经成功
        scene.value = 0;//切换场景       
        ElMessage({type: 'success',message: attrParams.id ? '修改成功' : '添加成功'}); //提示信息       
        getAttr();//获取全部已有的属性与属性值
    } else {
        ElMessage({type: 'error',message: attrParams.id ? '修改失败' : '添加失败'})
    }
}

       点击编辑按钮,需要切换场景值,并且将列表的数据赋值给收集数据对象,使用Object.assign方法实现数据的赋值操作。同理,点击保存和取消按钮,和新增的调用同一个方法。

 

5-删除属性

       我们点击列表页面的删除按钮,需要弹框,提示删除信息;删除成功和失败都弹出对应的信息;用到组件ElMessageel-popconfirm组件。

//删除某一个已有的属性方法回调
const deleteAttr = async (attrId: number) => {   
    let result: any = await reqRemoveAttr(attrId);//发相应的删除已有的属性的请求   
    if (result.code == 200) {//删除成功
        ElMessage({type: 'success',message: '删除成功'})      
        getAttr();//获取一次已有的属性与属性值
    } else {
        ElMessage({type: 'error',message: '删除失败'})
    }
}

ps:由于数据存储在仓库中,离开了该组件,数据应该清空,所以我们在路由组件销毁的时候,把仓库分类相关的数据清空

import { watch, ref, reactive, nextTick, onBeforeUnmount } from 'vue';
//路由组件销毁的时候,把仓库分类相关的数据清空
onBeforeUnmount(() => {
    //清空仓库的数据 
    categoryStore.$reset();
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/636601.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IDEA在Maven settings.xml失效的情况下反编译代码

在我们日常的工作中有时候会遇到需要调试别人的代码的问题&#xff0c;这个时候别人往往会给你一个jar包&#xff0c;这个包里面的代码都是经过编译的&#xff0c;点击打开函数以后都是后缀是.class的文件&#xff0c;我们调试起来非常不方便&#xff0c;这个时候如果我们想要下…

Vue中如何进行剪贴板操作?

Vue中如何进行剪贴板操作&#xff1f; 在Web应用程序中&#xff0c;剪贴板&#xff08;Clipboard&#xff09;操作是非常常见的操作之一。Vue.js是一款流行的JavaScript框架&#xff0c;它提供了一些有用的工具来处理DOM元素和用户界面。本文将介绍如何在Vue.js中使用剪贴板操…

行业拐点已至?解码装备制造企业四大转型方向!

当前&#xff0c;国内外经济形势复杂严峻&#xff0c;不稳定、不确定性因素增多。装备制造业企业面对行业增速放缓、内外部环境变化的挑战&#xff0c;叠加国家政策的鼓励与引导&#xff0c;数字化转型已经成为装备制造企业的迫切需求。 01 装备制造业发展现状&#xff08;SWOT…

抛售股票提现15亿美元救急,英特尔「下手」Mobileye这颗「摇钱树」

本周&#xff0c;全球半导体巨头英特尔宣布&#xff0c;将出售旗下上市公司Mobileye的部分股权&#xff0c;预计价值约15亿美元&#xff0c;股份将从目前的99.3%降至约98.7%。截止昨天收盘&#xff0c;Mobileye的最新市值约为339.4亿美元&#xff08;同期&#xff0c;英特尔市值…

VSCode连接远程服务器上docker容器进行代码调试

VSCode连接远程服务器上docker容器进行代码调试 1、本教程默认已经在本地安装完毕VSCode&#xff0c;并且安装ssh2、本教程默认已经在服务器端安装完毕docker与nvidia-docker、ssh服务并自动启动、且容器内安装anaconda3、服务器端创建docker容器&#xff0c;并增加端口映射&am…

【JS】时间格式转化相差8小时的原因

文章目录 时间类型UTCGMTCST 出现时间转化中相差8小时的原因 时间类型 UTC 协调世界时&#xff0c;又称世界统一时间、世界标准时间、国际协调时间&#xff0c;简称UTC&#xff08;Coordinated Universal Time&#xff09; UTC8即为北京时间&#xff0c;目前一般认为UTC与GMT…

AIGC|我让AI来写今年高考作文

作者&#xff1a;谢凯 | 神州数码云基地-需求分析师 目录 一、人工智能究竟强在哪 //以ChatGPT为例&#xff0c;人工智能其优势何在&#xff1f; 二、BingAI如何处理高考作文 三、总结 一、人工智能究竟强在哪 随着ChatGPT&#xff08;Chat Generative Pre-trained Transfo…

Vue CLI在 CommonJS 模块中不支持顶级 await 语法的解决办法

这是因为默认情况下&#xff0c;Vue CLI 会将你的代码转换为 CommonJS 模块&#xff0c;而在 CommonJS 模块中不支持顶级 await 语法。 在vue3项目的utils里面的js文件中写export全局调用方法时&#xff0c;打包依赖报错&#xff1b; 解决办法: 新增依赖vue/cli-plugin-top-…

iToolab UnlockGo for Mac,iOS设备解锁工具

iToolab UnlockGo是一款专业的 iPhone/iPad 解锁工具&#xff0c;可以帮助用户解除 iOS 设备的各种锁定&#xff0c;包括屏幕密码、指纹密码、Face ID 等。以下是 iToolab UnlockGo 的一些主要特点&#xff1a; 针对多种锁定类型&#xff1a;iToolab UnlockGo 可以解除多种 iO…

对数组的“reg [7:0] a_tmp[32:0]”理解

数组 在verilog中&#xff0c;对数组reg [7:0] a_tmp[32:0]进行操作时&#xff0c;分不清楚先对[32:0]进行操作还是先对 [7:0]进行操作&#xff0c;为此进行下面的实验。进一步加深对数组的理解。 实验1&#xff1a; reg [7:0] a_tmp[32:0];遍历的方式&#xff1a; integer …

架构师日记-从技术角度揭露电商大促备战的奥秘 | 京东云技术团队

一 背景 今年的618大促已经如期而至&#xff0c;接下来我会从技术的角度&#xff0c;跟大家聊聊大促备战的底层逻辑和实战方案&#xff0c;希望能够解答大家心中的一些疑惑。 首先&#xff0c;618大促为什么如此重要呢&#xff1f;先从数据的角度简单做一下分析&#xff0c;以…

Arcgis根据经纬度获得点的地理信息/行政区划信息

步骤可以总结为&#xff1a; 导入shp文件&#xff08;面数据&#xff0c;也就是行政区划的依据&#xff09; 导入栅格数据 将栅格数据落入到坐标系中 将导入的栅格点导出为shp图层 栅格点与面数据连接对齐 导出结果 1、导入shp文件&#xff08;面数据&#xff0c;也就是行…

去中心化的信任,Web3如何塑造更加牢固的客户忠诚度

在当今数字化的时代&#xff0c;客户忠诚度对于企业的成功至关重要。而随着Web3技术的崛起&#xff0c;我们正面临着一场信任的革命。本文将探讨Web3如何塑造更加牢固的客户忠诚度&#xff0c;并为企业带来长期的商业价值。 1.去中心化的信任机制 在传统的Web2模式下&#xff…

支付宝小程序开发

支付宝小程序商城是一种基于支付宝平台开发的小程序应用&#xff0c;它可以帮助商家在小程序中完成商品展示、下单购买、在线支付等操作。下面我们来介绍支付宝小程序商城的好处。 一、便捷快速 支付宝小程序商城可以直接在支付宝App中使用&#xff0c;无需下载和安装&#x…

InstructGPT:Training language models to follow instructions with human feedback

Training language models to follow instructions with human feedback 通过人类反馈的微调&#xff0c;在广泛的任务中使语言模型与用户的意图保持一致 aligning language models with user intent on a wide range of tasks by fine-tuning with human feedback 实验动机 …

【学习日记2023.6.12】之nacos配置管理_Feign远程调用_Gateway服务网关

文章目录 6. Nacos配置管理6.1 统一配置管理6.1.1 在nacos中添加配置文件6.1.2 从微服务拉取配置6.2 配置热更新 6.3 配置共享6.4 Nacos集群搭建6.4.1 集群结构图6.4.2 搭建集群初始化数据库下载nacos配置Nacos启动nginx反向代理优化 7. Feign远程调用7.1 Feign替代RestTemplat…

华为OD机试真题B卷 Java 实现【最少数量线段覆盖】,附详细解题思路

一、题目描述 给定坐标轴上的一组线段,线段的起点和终点均为整数并且长度不小于1,请你从中找到最少数量的线段,这些线段可以覆盖住所有线段。 二、输入描述 第一行输入为所有线段的数量,不超过10000,后面每行表示一条线段,格式为"x,y",x和y分别表示起点和终…

CentOS 查看某个目录:已用、可用空间情况

命令&#xff1a;df -h 目录 例如&#xff1a;df -h /home

【SpringMVC】| 报文信息转换器HttpMessageConverter

目录 框架搭建 报文信息转换器HttpMessageConverter 1. RequestBody注解 2. RequestEntity类型 3. RequestBody注解&#xff08;常用&#xff09; 重点&#xff1a;SpringMVC处理json 重点&#xff1a;SpringMVC处理ajax 重点&#xff1a;RestController注解 4. Respo…

knife4j接口文档

knife4j可以通过访问本地页面&#xff0c;实现对项目接口的管理&#xff1a;这样我们就不需要用postman软件调用接口了。 Mevan导包&#xff1a; <dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</ar…