当前位置: 首页 > news >正文

网站开发的人李海涛帮做装修设计的网站

网站开发的人李海涛,帮做装修设计的网站,wordpress表白模板下载,做外贸网站违法吗你的 Loading 开箱即可用的 loading#xff0c; 说明#xff1a;vue3-loading 是一个方便在 Vue 3 项目中使用的加载指示器组件的 npm 插件。它允许您轻松地在项目中添加加载动画#xff0c;提升用户体验。 目录 你的 Loading#x1f30d; 安装#x1f6f9; 演示地址…你的 Loading 开箱即可用的 loading 说明vue3-loading 是一个方便在 Vue 3 项目中使用的加载指示器组件的 npm 插件。它允许您轻松地在项目中添加加载动画提升用户体验。 目录 你的 Loading 安装 演示地址 使用方法说明 你的 Pinia 加密插件 安装 使用方法 加密和解密 安装 npm install vue3-loading-plug演示地址 http://project.webcats.cn/bx/43924/16191 使用方法 说明 内置两种loading 【可自行配置】 ​ Loading 是 大loading 可以用于刷新项目页面、路由跳转 。在路由中引入一次 即可全局生效极简配置 ​ smallLoading 是小圆圈 loading一般用于接口请求展示。可以请求拦截器中开启全局接口生效极简配置 在你的主应用程序入口文件例如 main.js中导入并使用 loading import Loading from vue3-loading-plug; app.use(Loading).mount(#app);如果是 ts 请在 global.d.ts 加入 类型 declare module vue3-loading-plug;router router.beforeEach((to, from, next) {if (to.meta.loading) app.config.globalProperties.$Loading.showLoading();next(); });router.afterEach((to) {if (to.meta.loading) app.config.globalProperties.$Loading.hideLoading(); });scrvies // 请求拦截器 service.interceptors.request.use((config) {// 在发送请求之前做些什么app.config.globalProperties.$smallLoading.showLoading();return config;},(error) {// 对请求错误做些什么app.config.globalProperties.$smallLoading.hideLoading();return Promise.reject(error);} );// 封装错误提示函数 Token过期、网络链接错误等 const tipError (value: string, title: string) {ElMessageBox.alert(value, title, {confirmButtonText: 重新登录,type: warning,}).then(() {// Session.clear(); // 清除临时缓存// 清除cookiedocument.cookie.split(;).forEach(fnction (c) {document.cookie c.replace(/^ /, ).replace(/.*/, ;expires new Date().toUTCString() ;path/);});window.location.reload(); // 刷新页面}); };// 响应拦截器 service.interceptors.response.use((response) {// 对响应数据做点什么 这里只返回成功响应数据app.config.globalProperties.$smallLoading.hideLoading();return response.data;},(error) {// 对响应错误数据做点什么这里只显示错误消息app.config.globalProperties.$smallLoading.hideLoading();/* axios.isCancel(error) 是 Axios 库中的一个方法用于判断一个错误对象是否是由于请求取消导致的。当使用 axios.CancelToken 取消请求时会抛出一个带有一个 message 属性的错误对象。axios.isCancel(error) 的作用就是判断这个错误对象的类型如果是由请求取消导致的错误则返回 true否则返回 false。console.log(打印cancelToken.cancel(xxx)传入来的值, error.message);*/if (axios.isCancel(error)) {ElMessage.error(error.message); // 显示错误消息} else {// 不是由请求取消导致的错误let errorMessage; // 错误提示变量const statusData error.response?.data; // 错误data数据const describeForNameMap [[() error.message.indexOf(timeout) ! -1,() (errorMessage 网络超时 ),],[() error.message Network Error,() (errorMessage 网络连接错误 ),],[() statusData.code 100010011,() {// 100010011 token过期errorMessage statusData.message;tipError(errorMessage, 登录过期);},],// 否则 显示错误消息[() statusData, () (errorMessage statusData.message)],];// 获取符合条件的子数组const getDescribe describeForNameMap.find((item) item[0]());// 执行子数组中的函数getDescribe getDescribe[1]();ElMessage.error(errorMessage); // 显示错误消息}} );// 导出 service将其命名为axios , 同时还导出了一个名为cancelToken的变量取消请求 export { service as axios, cancelToken }; 你的 Pinia 加密插件 你的 Pinia 加密插件是一个基于 Pinia 的实用工具用于在 Vue.js 应用程序中加密和解密敏感数据。它提供了一种简单且安全的方式来保护你的数据。 安装 你可以使用 npm 或 yarn 安装插件 pnpm i vue3-encryption-plugin使用方法 在你的主应用程序入口文件例如 main.js中导入并使用 Pinia store 以及加密插件 // main.js import { createApp } from vue; import { createPinia } from pinia; import App from ./App.vue; import EncryptionPlugin from vue3-encryption-plugin;const app createApp(App);const pinia createPinia(); app.use(pinia);// 注册加密插件并提供自定义的密钥可选例如随机的字符串 app.use(EncryptionPlugin, { key: your-custom-secret-key });app.mount(#app);加密和解密 一旦你设置了插件你就可以在组件中使用 $encrypt 和 $decrypt 方法 第一种 getCurrentInstance() !-- YourComponent.vue --import { getCurrentInstance } from vue;setup(){// 获取当前组件的上下文下面两种方式都能获取到组件的上下文。const { ctx } getCurrentInstance(); // 方式一这种方式只能在开发环境下使用生产环境 下的ctx将访问不到const { proxy }: any getCurrentInstance(); // 方式二此方法在开发环境以及生产环境下都能到组件上下文对象推荐// ctx 中包含了组件中由ref和reactive创建的响应式数据对象,以及以下对象及方法;proxy.$attrsproxy.$dataproxy.$elproxy.$emitproxy.$forceUpdateproxy.$nextTickproxy.$optionsproxy.$parentproxy.$propsproxy.$refsproxy.$rootproxy.$slotsproxy.$watch}function handClick() {console.log(这里输出 ,proxy.$encryptionPlugin.encryptData({ name: zk, age: 26}));console.log(这里输出 ,proxy.$encryptionPlugin.decryptData(U2FsdGVkX1/PBDHn2pyLPAf6DmolvylM2QEIDhcf5I3WQWhOh19eos0uZfdbzdDP)); }第二种 injict (推荐) 1src / types / global.d.ts 定义类型 // 加密解密 declare interface EncryptionPlugin {encryptData: T(data: T) string;decryptData: T(encryptedData: string) T; }如果你使用 eslint 请在 .eslintrc.cjs 文件中添加 globals: {// 以下是全局变量 eslint 不会报EncryptionPlugin is not defined.eslint no-undefEncryptionPlugin: readonly,$encryptionPlugin: readonly,},2 页面使用 script setup langts import { inject } from vue;// 使用 inject 函数获取 encryptionPlugin const encryptionPlugin inject(encryptionPlugin) as EncryptionPlugin;function handClick() {// 现在你可以在你的组件中使用 encryptData 和 decryptData 方法了const encryptedData encryptionPlugin.encryptData(Hello World);const decryptedData encryptionPlugin.decryptData(encryptedData);console.log(加密 , encryptedData);console.log(解密 , decryptedData); } /script
http://wiki.neutronadmin.com/news/35546/

相关文章:

  • 30天网站建设实录视频云盘电子版简历word格式
  • 如何查做的网站排名c语言做网站账号登录系统
  • 万网虚拟机怎么做两个网站怎么做个人网站建设
  • 微信小程序 网站建设高校网站建设 调查
  • 天津关键词优化服务济南网站怎么做seo
  • 黄页网站推广下载免费徐州商城建站系统
  • 成都市温江建设局网站建设部网站燃气管理部门
  • 做卖蜂蜜的网站计划书网站怎么做的有创意
  • 帮助做职业规划的网站免费推广引流平台app
  • 想开个影视网站 那有做的淄博亿泰信息技术有限公司
  • vps服务器怎么创建多个网站wordpress海外建站
  • 门户网站开发建设技术大型网站建设机构
  • 网站目录wordpress 自动内链 代码
  • 网站建设设计维片wordpress设置文件
  • 设计微信网站建设wiki wordpress
  • 江苏环泰建设有限公司网站建设治安总队网站目的
  • 宁波优化网站排名公司推荐如何看网站关键词
  • 网站怎么做抽奖企业网站ppt怎么做
  • 广元 网站建设深圳企业vi设计公司
  • 湖南郴州建设局网站黑龙江建设网官方网站特种作业
  • 微信小程序制作平台官网江苏seo和网络推广
  • 网站建设ppt方案模板下载石家庄网站制作找谁
  • 顺德建网站的公司asp网站数据库扫描
  • 网站不备案可以做淘宝联盟吗侧边导航条wordpress
  • 公司网站建设费怎么做账上海网站建设网络推广
  • 帝国行业网站模板中国免费网站服务器
  • 个性flash网站做网站需要哪些资质
  • 什么网站是最全的免费网络电视直播软件
  • 闸北微信网站建设古镇 网站建设
  • 免费网站模板带后台星月教你做网站回顾文档