Vue3项目练习详细步骤(第三部分:文章分类页面模块)

news2024/10/6 1:45:36

文章分类列表

主体结构 

接口文档

文章分类列表查询接口数据绑定

 Pinia状态管理库

axios请求拦截器 

Pinia持久化插件-persist 

未登录统一处理

添加文章分类 

主体结构 

 接口文档

 绑定请求数据

编辑文章分类

弹框结构 

 数据回显

 接口文档

绑定请求数据

删除分类 

接口文档

 绑定请求数据

 

文章分类列表

主体结构 

 在ArticleCategory.vue文件中完成文章分类列表组件

<script setup>
import {
    Edit,
    Delete
} from '@element-plus/icons-vue'
import { ref } from 'vue'
const categorys = ref([
    {
        "id": 3,
        "categoryName": "美食",
        "categoryAlias": "my",
        "createTime": "2023-09-02 12:06:59",
        "updateTime": "2023-09-02 12:06:59"
    },
    {
        "id": 4,
        "categoryName": "娱乐",
        "categoryAlias": "yl",
        "createTime": "2023-09-02 12:08:16",
        "updateTime": "2023-09-02 12:08:16"
    },
    {
        "id": 5,
        "categoryName": "军事",
        "categoryAlias": "js",
        "createTime": "2023-09-02 12:08:33",
        "updateTime": "2023-09-02 12:08:33"
    }
])
</script>
<template>
    <el-card class="page-container">
        <template #header>
            <div class="header">
                <span>文章分类</span>
                <div class="extra">
                    <el-button type="primary">添加分类</el-button>
                </div>
            </div>
        </template>
        <el-table :data="categorys" style="width: 100%">
            <el-table-column label="序号" width="100" type="index"> </el-table-column>
            <el-table-column label="分类名称" prop="categoryName"></el-table-column>
            <el-table-column label="分类别名" prop="categoryAlias"></el-table-column>
            <el-table-column label="操作" width="100">
                <template #default="{ row }">
                    <el-button :icon="Edit" circle plain type="primary" ></el-button>
                    <el-button :icon="Delete" circle plain type="danger"></el-button>
                </template>
            </el-table-column>
            <template #empty>
                <el-empty description="没有数据" />
            </template>
        </el-table>
    </el-card>
</template>

<style lang="scss" scoped>
.page-container {
    min-height: 100%;
    box-sizing: border-box;

    .header {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
}
</style>

保存查看

接口文档

详细接口文档链接:https://blog.csdn.net/dafsq/article/details/138500082?spm=1001.2014.3001.5502 

文章分类列表查询接口数据绑定

在api目录下新建article.js文件

完成分类列表查询请求方法 

//导入请求工具文件
import request from '@/utils/request.js'

//文章分类列表查询
export const ArticleCategoryListService = () => {
    return request.get('/category')
}

 在文章分类ArticleCategory.vue文件中声明文章分类列表查询异步函数

//声明文章分类列表查询异步函数
import {articleCategoryListService} from '@/api/article.js'
const articleCategoryList = async() => {
    let result = await articleCategoryListService();
    if(result.code == 0){
        //成功获取
        categorys.value = result.data;
    }else{
        //获取失败
        ElMessage.error('获取失败')
    }
}
//调用
articleCategoryList();

 Pinia状态管理库

 Pinia是Vue的专属状态管理库,它允许你跨组件或页面共享状态

在项目目录下安装pinia

npm install pinia

在main.js文件中应用实例中使用pinia

创建src/stores/token.js文件 在其中定义store

在登录页面Login.vue文件中定义tokenStore并把登录时的token存入pinia

axios请求拦截器 

        当进入主页后,将来要与后台交互,都需要携带token,如果每次请求都写这样的代码,将会比较繁琐,此时可以将携带token的代码通过请求拦截器统一处理

在请求工具request.js文件中使用axios请求拦截器将token以请求头的方式携带请求

//导入token状态
import { useTokenStore } from '@/stores/token.js';
//添加请求拦截器
instance.interceptors.request.use(
    (config)=>{
        //在发送请求之前做什么
        let tokenStore = useTokenStore()
        //如果token中有值,在携带
        if(tokenStore.token){
            config.headers.Authorization=tokenStore.token
        }
        return config
    },
    (err)=>{
        //如果请求错误做什么
        Promise.reject(err)
    }
)

 保存可以查看到账号中已有的文章分类信息

Pinia持久化插件-persist 

  • Pinia默认是内存存储,当刷新浏览器的时候会丢失数据。
  • Persist插件可以将pinia中的数据持久化的存储 

在项目目录下安装persist

npm install pinia-persistedstate-plugin

在main.js文件在pinia中使用persist

在token.js文件中定义状态Store时指定持久化配置参数,在defineStore函数中添加第三个参数

 

这样登录刷新后token持久保存 就不会报错了 

 

未登录统一处理

        在后续访问接口时,如果没有登录,则前端不携带token,后台服务器会返回响应状态码401,代表未登录,此时可以在axios的响应拦截器中,统一对未登录的情况做处理

//导入Element-Plus提示框组件
import { ElMessage } from 'element-plus'

//导入路由
import router from '@/router/router.js'
//添加响应拦截器
instance.interceptors.response.use(
    result=>{
        return result.data;
    },
    err=>{
        //如果响应状态码时401,代表未登录,给出对应的提示,并跳转到登录页
        if(err.response.status===401){
            ElMessage.error('请先登录!')
            router.push('/login')
        }else{
            ElMessage.error('服务异常');
        }
        return Promise.reject(err);//异步的状态转化成失败的状态
    }
)

 

添加文章分类 

主体结构 

在ArticleCategory.vue文件中添加分类弹窗组件

                <!-- 添加分类弹窗 -->
        <el-dialog v-model="dialogVisible" title="添加弹层" width="30%">
            <el-form :model="categoryModel" :rules="rules" label-width="100px" style="padding-right: 30px">
                <el-form-item label="分类名称" prop="categoryName">
                    <el-input v-model="categoryModel.categoryName" minlength="1" maxlength="10"></el-input>
                </el-form-item>
                <el-form-item label="分类别名" prop="categoryAlias">
                    <el-input v-model="categoryModel.categoryAlias" minlength="1" maxlength="15"></el-input>
                </el-form-item>
            </el-form>
            <template #footer>
                <span class="dialog-footer">
                    <el-button @click="dialogVisible = false">取消</el-button>
                    <el-button type="primary"> 确认 </el-button>
                </span>
            </template>
        </el-dialog>

 添加表单校验和数据模型

//控制添加分类弹窗
const dialogVisible = ref(false)

//添加分类数据模型
const categoryModel = ref({
    categoryName: '',
    categoryAlias: ''
})
//添加分类表单校验
const rules = {
    categoryName: [
        { required: true, message: '请输入分类名称', trigger: 'blur' },
    ],
    categoryAlias: [
        { required: true, message: '请输入分类别名', trigger: 'blur' },
    ]
}

在添加分类按钮处绑定显示弹窗的单击事件

<el-button type="primary" @click="dialogVisible = true">添加分类</el-button>

点击添加文章按钮时弹窗正常显示

 绑定数据模型

绑定校验规则

已绑定成功

 绑定取消按钮事件,使弹框不显示

 接口文档

 绑定请求数据

在article.js文件中添加请求函数

//文章分类添加
export const articleCategoryAddService = (categoryModel) => {
    return request.post('/category',categoryModel)
}

在文章分类页面ArticleCategory.vue文件中添加单击事件请求函数

//导入Element-Plus提示框组件
import { ElMessage } from 'element-plus'
//导入articleCategoryAddService函数
import {articleCategoryAddService} from '@/api/article.js'
const addCategory = async () => {
    let result = await articleCategoryAddService(categoryModel.value);
    if(result.code == 0){
        //成功添加
        ElMessage(result.message? result.message:'添加成功')
        //隐藏弹窗
        dialogVisible.value = false
        //再次访问后台接口,查询所有分类
        articleCategoryList();
    }else{
        //添加失败
        ElMessage.error('添加失败')
    }
}

在确认按钮中绑定该事件函数 

<el-button type="primary" @click="addCategory"> 确认 </el-button>

 

编辑文章分类

弹框结构 

 在编辑按钮处添加事件,点击后显示弹框

<el-button :icon="Edit" circle plain type="primary" @click="dialogVisible = true"></el-button>

定义变量控制弹窗标题 

//定义变量控制弹窗标题
const title=ref('')

在弹窗标题中绑定变量

<el-dialog v-model="dialogVisible" :title="title" width="30%">

 在添加分类按钮中赋值给标题变量

<el-button type="primary" @click="dialogVisible = true;title='添加分类'">添加分类</el-button>

在编辑按钮中赋值标题变量

<el-button :icon="Edit" circle plain type="primary" @click="dialogVisible = true;title='编辑分类'"></el-button>

 保存之后点击不同的按钮将会显示对应的弹框标题

 数据回显

 定义数据回显函数

//修改分类回显
const updateCategoryEcho = (row) => {
    title.value = '修改分类'
    dialogVisible.value = true
    //将row中的数据赋值给categoryModel
    categoryModel.value.categoryName=row.categoryName
    categoryModel.value.categoryAlias=row.categoryAlias
    //修改的时候必须传递分类的id,所以扩展一个id属性
    categoryModel.value.id=row.id
}

 通过插槽的方式得到被点击按钮所在行的数据

    <template #default="{ row }">
        <el-button :icon="Edit" circle plain type="primary" @click="updateCategoryEcho(row)"></el-button>
        <el-button :icon="Delete" circle plain type="danger"></el-button>
    </template>

保存后点击编辑 文本框回显效果

 

 接口文档

 

绑定请求数据

在article.js文件中添加请求函数

 在文章分类页面ArticleCategory.vue文件中添加修改文章分类单击事件请求函数

//导入articleCategoryUpdateService函数
import {articleCategoryUpdateService} from '@/api/article.js'
//修改分类
const updateCategory=async ()=>{
        let result = await articleCategoryUpdateService(categoryModel.value)
        if(result.code == 0){
            ElMessage.success(result.message? result.message:'修改成功')
            //隐藏弹窗
            dialogVisible.value=false
            //再次访问后台接口,查询所有分类
            articleCategoryList();
    }else{
        //添加失败
        ElMessage.error('修改失败')
    }
}

由于现在修改和新增共用了一个数据模型,所以在点击添加分类后,有时候会显示数据,此时可以将categoryModel中的数据清空  

//清空模型数据
const clearData = ()=>{
    categoryModel.value.categoryName='',
    categoryModel.value.categoryAlias=''
}

 修改确定按钮的绑定事件

<el-button type="primary" @click="title==='添加分类'? addCategory():updateCategory()"> 确认 </el-button>

 修改添加按钮的点击事件

<el-button type="primary" @click="dialogVisible = true;title='添加分类';clearData()">添加分类</el-button>

 保存之后就能完成添加和修改的功能了

删除分类 

接口文档

 

 绑定请求数据

 在article.js文件中添加请求函数

//删除分类
export const articleCategoryDeleteService = (id) => {
    return request.delete('/category?id='+id)
}

  在文章分类页面ArticleCategory.vue文件中编写删除文章分类单击事件请求函数并在函数内部添加提示框组件

//导入element的ElMessageBox提示框组件
import { ElMessageBox } from 'element-plus'
//导入articleCategoryDeleteService函数
import {articleCategoryDeleteService} from '@/api/article.js'
//删除分类
const deleteCategory = (row) => {
    ElMessageBox.confirm(
        '确认是否删除该分类信息?',
        '提示',
        {
            confirmButtonText: '确认',
            cancelButtonText: '取消',
            type: 'warning',
        }
    )
        .then(async () => {
            //用户点击了确认
            let result = await articleCategoryDeleteService(row.id)
            ElMessage.success(result.message?result.message:'删除成功')
            //再次调用getAllCategory,获取所有文章分类
            articleCategoryList();
        })
        .catch(() => {
            //用户点击了取消
            ElMessage({
                type: 'info',
                message: '取消删除',
            })
        })
}

 在删除图标按钮处绑定该点击事件函数

<el-button :icon="Delete" circle plain type="danger" @click="deleteCategory(row)"></el-button>

 保存后即可正常删除文章分类

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

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

相关文章

CPU占用率很高,相应很慢排查思路

获取线程状态 通过top -c命令可以动态显示进程及其占用资源的排行榜 可以看到&#xff0c;CPU占用率100%的PID是80972&#xff0c;定位到该进程之后&#xff0c;我们再从线程的dump日志中去定位. 使用top -H -p 80972命令查找到该进程中消耗CPU最多的线程&#xff0c;从下面的…

海外社媒账号如何运营安全稳定?

由于设备与网络原因&#xff0c;通常一个海外社媒账号尤其是多账号的稳定性都有一定限制&#xff0c;错误的操作或者网络都可能使得账号被封&#xff0c;前功尽弃。本文将为大家讲解如何通过IP代理来维持账号稳定与安全&#xff0c;助力海外社媒矩阵的搭建。 一、社媒账号关联…

金蝶云星空数据库迁移后,显示 error: 40 - 无法打开到 SQL Server 的连接的解决方法

原因&#xff1a;数据库迁移/或者更新IP后&#xff0c;与之前添加的数据库地址不一致导致无法连接数据库&#xff1b; 解决方法&#xff1a;修改IP为目前数据库的IP&#xff1b; 文件路径&#xff1a;在ManageSite\APP_Data\Common.config中&#xff0c;修改DbServerInstance…

数据源不同?奥威BI软件是这么做的

面对数据源不同的情况&#xff0c;BI&#xff08;商业智能&#xff09;软件如奥威BI软件通常通过一系列技术和方法来实现数据的整理。以下以奥威BI软件为例&#xff0c;详细解释其如何整理不同数据源的数据&#xff1a; 数据收集&#xff1a; 爬虫技术&#xff1a;奥威BI软件…

【车载开发系列】Autosar DEM中重要配置项说明

【车载开发系列】Autosar DEM中重要配置项目 【车载开发系列】Autosar DEM中重要配置项目说明 【车载开发系列】Autosar DEM中重要配置项目1&#xff09;DemDtcStatusAvailabilityMask2&#xff09;DemTypeOfDTCSupported3&#xff09;DemFreezeFrameCapture4&#xff09;DemIm…

3D模型三角面转四角面操作指南---模大狮模型网

在3D建模的过程中&#xff0c;三角面(Triangles)和四角面(Quads)是两种常见的多边形类型。虽然三角面在渲染速度和计算效率上有其优势&#xff0c;但四角面在模型编辑和纹理映射上通常更为方便。因此&#xff0c;将三角面转换为四角面是建模过程中常见的需求。 一、选择合适的建…

【YOLOv5/v7改进系列】引入AKConv——即插即用的卷积块

一、导言 介绍了一种名为AKConv&#xff08;Alterable Kernel Convolution&#xff09;的新型卷积操作&#xff0c;旨在解决标准卷积操作存在的两个根本性问题。首先&#xff0c;标准卷积操作受限于局部窗口&#xff0c;无法捕获来自其他位置的信息&#xff0c;且其采样形状固…

URL在线编码解码

URL在线编码解码 打开网站 在线工具网-梦幻加菲猫 选择“URL编码解码” 输入需要编码/解码的内容&#xff0c;点击“编码”/“解码”按钮 编码&#xff1a; 解码&#xff1a; 复制已经编码/解码后的内容。

Mac安装tomcat

代码 brew install tomcat 运行结果如下&#xff1a; 如果要启动输入&#xff1a; brew services start tomcat

php 安装 swoole扩展

一 在swoole官网查询适配版本Swoole 文档 2. php环境为7.3下载 4.8 ​ wget https://pecl.php.net/get/swoole-4.6.6.tgztar -zxvf swoole-4.6.6.tgzcd swoole-4.6.6/usr/local/php7/bin/phpize​ ./configure --enable-openssl --enable-sockets --enable-mysqlnd --enabl…

【车载开发系列】Vector工具链的安装

【车载开发系列】Vector工具链的安装 【车载开发系列】Vector工具链的安装 【车载开发系列】Vector工具链的安装一. VectorDriver二. DaVinci_Developer三. DaVinci Configurator 一. VectorDriver Vector Driver Setup是Vector产品链中重要的驱动软件,所有的硬件设备进行连接…

springboot课程题库管理系统-计算机毕业设计源码30812

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于课程题库管理系统 当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了课程题库管理系统 &#xff0c;它彻底改变了…

基于深度学习的中文情感分析系统python flask

基于python的毕业设计 基于深度学习的中文情感分析系统(flask)(源码说明文档演示) 毕业设计课程设计期末大作业、课程设计、高分必看&#xff0c;下载下来&#xff0c;简单部署&#xff0c;就可以使用。 包含&#xff1a;项目源码、数据库脚本、软件工具等&#xff0c;该项目…

R语言入门 | 使用 dplyr 进行数据转换

3.1简介 3.1.1准备工作 3.1.2 dplyr 基础 • 按值筛选观测&#xff08; filter() &#xff09;。 • 对行进行重新排序&#xff08; arrange() &#xff09;。 • 按名称选取变量&#xff08; select() &#xff09;。 • 使用现有变量的函数创建新变量&#xff08; …

企业如何打造通证经济生态闭环详解(中)

全球化企业通证积分管理系统中通证积分如何发行&#xff1f; 首先提倡的是健康、绿色的通证资产&#xff0c;所有的通证资产不能通过与现金的买卖获得&#xff0c;是通过在平台完成对应的任务获得&#xff0c;是通过奖励的形式释放给用户。主要有哪些形式的任务可以释放通证积…

失落的方舟 命运方舟台服怎么下载游戏客户端 游戏账号怎么注册

《失落的方舟》&#xff08;Lost Ark&#xff09;是韩国Smilegate公司精心打造的一款大型多人在线角色扮演游戏&#xff08;MMORPG&#xff09;&#xff0c;以其精美的画面、沉浸式的剧情、类似动作游戏的战斗体验和广阔的开放世界设定&#xff0c;自面世以来便深受全球玩家喜爱…

【深度好文】AI企业融合联盟营销,做的好就是最大赢家!

AI工具市场正在迅速发展&#xff0c;现仍有不少企业陆续涌出&#xff0c;那么如何让你的工具受到目标群体的关注呢&#xff1f;这相比是AI工具营销人员一直在思考的问题。 即使这个市场正蓬勃发展&#xff0c;也无法保证营销就能轻易成功。AI工具虽然被越来越多人认可和接受&a…

【C language】判断一个正整数是否是2^n

题解&#xff1a;判断一个正整数是否是2^n(位运算方法) 1.题目 判断一个正整数是否是2^n 2.位运算法 思路&#xff1a;干掉二进制最右边的1&#xff0c;看是否是0 int main() {int num 16;if ((num & (num - 1)) 0) printf("the num is a 2^n");else print…

Python 之微信指数小程序数据抓取

Fiddler安装和设置 安装 Fiddler 安装包可以从这里获取&#xff0c;如果失效了可以自己网上找一个安装。 链接&#xff1a;https://pan.baidu.com/s/1N30BoDWm2_dBL8i8GRzK5g?pwd1znv 提取码&#xff1a;1znv 然后就是点击安装就好了&#xff0c;没什么好多说的。 启用…

100道面试必会算法-26-删除排序链表中的重复元素

100道面试必会算法-26-删除排序链表中的重复元素|| 链表是一种常见的数据结构&#xff0c;它以节点的形式存储数据&#xff0c;每个节点包含数据以及指向下一个节点的引用。链表在插入和删除操作上有较高的效率&#xff0c;因此在许多应用中得到了广泛的使用。然而&#xff0c…