vue3项目中的常用插件

vue3项目中的常用插件

1、路由组件

npm install vue-router@4

路由配置

import { createWebHashHistory, createRouter } from "vue-router";
//引入主布局
import Admin from "@/pages/layout/admin.vue";
import Index from "@/pages/index/index.vue";
import NotFound from "@/pages/error/404.vue";
import Login from "@/pages/login/index.vue"const routes = [{path:'/',component:Admin,children:[{path: "/",component: Index,meta:{title:'后台首页'}},]},{path:'/login',component:Login,meta:{title:'登录'}},{path: "/:pathMatch(.*)*",name: "NotFound",component: NotFound,},
];const router = createRouter({history: createWebHashHistory(),routes,
});export  {router}

路由守卫

import { getCookie } from "@/utils";
import { router } from "@/router";
import { store } from "@/store";
import { showLoading,hiddenLoading } from "@/utils";//全局前置守卫
router.beforeEach(async (to, from, next) => {showLoading()const token = getCookie("token");// 如果token不存在 且路径不是loginif (!token && to.path != "/login") {return next({ path: "/login" });}// 如果token存在 路径为loginif (token && to.path == "/login") {return next({path: from.path ? from.path : "/",});}if (token) {// console.log('token is success')await store.dispatch('getUserInfo')// store.dispatch('getUseInfo')}//获取页面的title// const { title } = to.metalet title = (to.meta.title ? to.meta.title : "" ) + "-这里是标题" // console.log(title)// 设置页面的titledocument.title = title// console.log(to.meta)next();});
// 全局后置守卫
router.afterEach((to, from) => {hiddenLoading()
})

2、vuex 用来全局状态共享

npm install vuex@next --save

vuex的配置

import { createStore } from "vuex";
import { getInfo } from "@/api/manager";
export const store = createStore({state:{userInfo: { },},mutations: {// 修改state的值需要使用mutations里边的方法// 后期使用的时候 第一个参数为方法名  第二个参数为数据setUserInfo(state, userInfo) {state.userInfo = userInfo;},},actions:{getUserInfo({commit}){return new Promise((resolve,reject)=>{getInfo().then(res=>{commit('setUserInfo',res.data)resolve(res)}).catch(error=>reject(error))})},logout({commit}){commit('setUserInfo',{})}}
});

3、vuex的数据持久化

npm i vuex-persistedstate

配置

import { createStore } from "vuex"
... //导入模块
import createPersistedstate from "vuex-persistedstate" //引入本地化插件
const store  = createStore({modules:{......},plugins:[createPersistedstate({key:'',//本地存储的名字//需要持久化模块paths:["demo1","demo2",]})]
)

4、使用cookie

npm i @vueuse/core
npm i @vueuse/integrations
npm i universal-cookie

使用

import {useCookie} from "@vueuse/integrations/useCookies"const cookie = useCookies()
// get set remove

5、https请求 axios

npm install axios --save

axios配置

import axios from "axios"const service = axios.create({baseUrl:'',timeoute:2000,...
})//拦截器
// 添加请求拦截器
service.request.use(function (config) {// 在发送请求之前做些什么// 举例 添加头部const token = '' //从cookie或者其他地方获取if(token){config.headers.token = token// config.headers['token'] = token 推荐}return config;}, function (error) {// 对请求错误做些什么return Promise.reject(error);});// 添加响应拦截器
service.response.use(function (response) {// 对响应数据做点什么return response;}, function (error) {//获取响应码const status = error.reponse.statusif(status == 401){// 一般情况为未授权 执行未授权的逻辑 // 给出提示或者直接跳转到登录页面 router.push('/login') //假设已经引入路由}else if(status == ...){....}else{....}// 对响应错误做点什么return Promise.reject(error);});

6. loading插件

npm install nprogress

nprogress 配置

import nprogress from "nprogress"
// 启用loading
nprogress.start()
// 结束loading
nprogress.done()

其余插件为UI库,代码规范,代码检查,CSS预处理器等

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

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

相关文章

LeetCode Hot100 15.三数之和

题干: 思路: 首先想到的是哈希表,类似于两数之和的想法,共两层循环,将遍历到的第一个元素和第二个元素存入哈希表中,然后按条件找第三个元素,但是这道题有去重的要求,哈希表实现较为…

html + css 自适应首页布局案例

文章目录 前言一、组成二、代码1. css 样式2. body 内容3.全部整体 三、效果 前言 一个自适应的html布局 一、组成 整体居中&#xff0c;宽度1200px&#xff0c;小屏幕宽度100% 二、代码 1. css 样式 代码如下&#xff08;示例&#xff09;&#xff1a; <style>* {…

使用Axios函数库进行网络请求的使用指南

目录 前言1. 什么是Axios2. Axios的引入方式2.1 通过CDN直接引入2.2 在模块化项目中引入 3. 使用Axios发送请求3.1 GET请求3.2 POST请求 4. Axios请求方式别名5. 使用Axios创建实例5.1 创建Axios实例5.2 使用实例发送请求 6. 使用async/await简化异步请求6.1 获取所有文章数据6…

多仓库分支同步策略:方法与工具全解析

在大型项目或微服务架构中&#xff0c;多个仓库之间保持一致的分支结构是至关重要的。本文将为您介绍几种高效的方法和工具&#xff0c;帮助您实现这一目标。 方法一&#xff1a;Git Hooks——自动化同步的利器 Git Hooks允许您在特定事件&#xff08;如提交、合并等&#xf…

MySQL —— MySQL索引介绍、索引数据结构、聚集索引和辅助索引、索引覆盖

文章目录 索引概念索引分类索引数据结构种类Innodb 索引数据结构聚集索引和辅助索引&#xff08;非聚集索引&#xff09;聚集索引辅助索引&#xff08;非聚集索引&#xff09; 索引覆盖 索引概念 索引是对数据库表中一列或多列的值进行排序后的一种数据结构。用于帮助 mysql 提…

证明存在常数c, C > 0,使得在一系列特定条件下,某个特定投资时刻出现的概率与天数的对数成反比

在第0天&#xff0c;某债券价值1元。在第 n n n天&#xff0c;其价值为 S n : e ( X 1 ⋯ X n ) S_n : e^{(X_1 \cdots X_n)} Sn​:e(X1​⋯Xn​) 元&#xff0c;其中 X i X_i Xi​ 是独立同分布随机变量&#xff0c;满足 P ( X i 1 ) P ( X i − 1 ) 1 / 2 P(X_i 1)…

Vue.js中computed的使用方法

在Vue.js中&#xff0c;computed 属性是基于它们的依赖进行缓存的响应式属性。只有当相关依赖发生改变时&#xff0c;才会重新求值。这意味着只要computed属性依赖的源数据&#xff08;如data中的属性&#xff09;没有发生变化&#xff0c;多次访问computed属性会立即返回之前的…

制作图片马常用的五种方法总结

目录 1. 以文本方式2. Windows的cmd方式3. PhotoShop方式4. 16进制5. Linux的cat方式 图片马:就是在图片中隐藏一句话木马。利用.htaccess等解析图片为PHP或者asp文件。达到执行图片内代码目的。 1. 以文本方式 用文本方式&#xff08;这里用notepad。如果用记事本的方式打开…

python isinstance(True, int)

今天的bug 是布尔类型给的。 >>> a True >>> isinstance(a, int) True>>> a True >>> isinstance(a, bool) True‌Python中的布尔类型&#xff08;bool&#xff09;实际上是整数类型&#xff08;int&#xff09;的一个子类&#xff0c;…

python实现十进制转换二进制,tkinter界面

目录 需求 效果 代码实现 代码解释 需求 python实现十进制转换二进制 效果 代码实现 import tkinter as tk from tkinter import messageboxdef convert_to_binary():try:# 获取输入框中的十进制数decimal_number int(entry.get())# 转换为二进制binary_number bin(de…

UG Motion学习笔记2【正解 反解】

使用软件&#xff1a;SP Model NX12.0 Robot Arm的正解&#xff1a; &#xff08;先添加关节驱动&#xff0c;进行正解。再添加连杆驱动&#xff0c;进行反解。&#xff09; 直接点击_step.prt零件打开。一共7个构件&#xff0c;6个运动副&#xff08;圆片&#xff0c;转角&…

机器学习—正则化和偏差或方差

正则化参数的选择对偏差和方差的影响 用一个四阶多项式&#xff0c;要用正则化拟合这个模型&#xff0c;这里的lambda的值是正则化参数&#xff0c;它控制着你交易的金额&#xff0c;保持参数w与训练数据拟合&#xff0c;从将lambda设置为非常大的值的示例开始&#xff0c;例如…

在Node.js中如何使用TypeScript

第一步&#xff1a;创建一个Node.js项目的package.json文件 npm init -y第二步&#xff1a;添加TypeScript、添加node.d.ts npm install typescript -D npm install types/node -D第三步&#xff1a;初始化一个tsconfig.json文件 npx tsc --init --rootDir src --outDir lib…

零基础Java第十九期:认识String(一)

目录 一、String的重要性 二、String的常用方法 2.1. 字符串构造 2.2. String对象的比较 2.3. 字符串查找 2.4. 转化 2.4. 字符串替换 2.5. 字符串拆分 2.6. 字符串截取 一、String的重要性 在C语言中已经涉及到字符串了&#xff0c;但是在C语言中要表示字符串只能…

面试经典 150 题:20、2、228、122

20. 有效的括号 参考代码 #include <stack>class Solution { public:bool isValid(string s) {if(s.size() < 2){ //特判&#xff1a;空字符串和一个字符的情况return false;}bool flag true;stack<char> st; //栈for(int i0; i<s.size(); i){if(s[i] ( |…

【SpringBoot】公共字段自动填充

问题引入 JavaEE开发的时候&#xff0c;新增字段&#xff0c;修改字段大都会涉及到创建时间(createTime)&#xff0c;更改时间(updateTime)&#xff0c;创建人(craeteUser)&#xff0c;更改人(updateUser)&#xff0c;如果每次都要自己去setter()&#xff0c;会比较麻烦&#…

深度学习-卷积神经网络CNN

案例-图像分类 网络结构: 卷积BN激活池化 数据集介绍 CIFAR-10数据集5万张训练图像、1万张测试图像、10个类别、每个类别有6k个图像&#xff0c;图像大小32323。下图列举了10个类&#xff0c;每一类随机展示了10张图片&#xff1a; 特征图计算 在卷积层和池化层结束后, 将特征…

微服务即时通讯系统的实现(客户端)----(3)

目录 1. 聊天界面逻辑1.1 发送消息1.2 接收消息 2. 个人信息详情逻辑2.1 加载个人信息2.2 修改昵称2.3 修改签名2.4 修改电话 (1) - 发起短信验证码2.5 修改电话 (2) - 修改电话逻辑2.6 修改头像 3. 用户详细信息界面逻辑3.1 获取指定用户的信息3.2 点击 "发送消息" …

stm32——通用定时器时钟知识点

&#xff08;该图来自小破站 铁头山羊老师的stm32标准库教学&#xff09;

SobarQube实现PDF报告导出

文章目录 前言一、插件配置二、使用步骤1.新生成一个Token2.将拷贝的Token加到上文中执行的命令中3.查看报告 三、友情提示总结 前言 这篇博文是承接此文 .Net项目在Windows中使用sonarqube进行代码质量扫描的详细操作配置 描述如何导出PDF报告 众所周知&#xff0c;导出PDF功…