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

做网站推广也要营业执照吗校园网站建设结论

做网站推广也要营业执照吗,校园网站建设结论,站长之家工具查询,网站开发方法有哪些目录 总结一、步骤1.安装Axios:2.axios对象封装3.请求api封装4.使用pinia临时库保存响应信息(按需求用)5.最后,在组件中使用! 总结 封装axios对象,编写公共请求代码、添加拦截逻辑、然后分层实现axios请求…

目录

  • 总结
  • 一、步骤
    • 1.安装Axios:
    • 2.axios对象封装
    • 3.请求api封装
    • 4.使用pinia临时库保存响应信息(按需求用)
    • 5.最后,在组件中使用!


总结

封装axios对象,编写公共请求代码、添加拦截逻辑、然后分层实现axios请求的调用!

一、步骤

1.安装Axios:

  • 首先,确保你的项目中已经安装了Axios。如果没有安装,可以通过以下命令安装Axios:
npm install axios

2.axios对象封装

  • 创建一个名为request.js的文件,用于封装Axios对象。
import axios from 'axios'
import { Message } from 'element-ui'
import {tokenStore} from "@/store/store";// 创建一个 Axios 实例
const axiosInstance = axios.create({baseURL: 'http://localhost:8080/qy', // 通用后端 Url 地址timeout: 5000, // 请求最大等待时间,headers: { 'Content-Type': 'application/json' },
})// 添加请求拦截器
axiosInstance.interceptors.request.use((config) => {// 获取请求的URLconst requestUrl = config.url;console.log(requestUrl);// console.log(config);// 提取URL路径部分/qy/Login// const urlPath = new URL(requestUrl).pathname;// 如果是post请求将参数data转成json字符串// 检查请求方法是否为 POSTif (config.method === 'post' || config.method === 'POST') {// 将请求数据转换为 JSON 字符串config.data = JSON.stringify(config.data);// 设置请求头的 Content-Type// config.headers['Content-Type'] = 'application/json';}// 在请求头中添加令牌信息const jwtToken = tokenStore().jwtToken // 从pinia中获取令牌// 检查是否是登录请求,这里假设登录请求的URL是 '/Login'if (requestUrl !== '/Login' && requestUrl !== '/LogOut') {console.log(requestUrl);// 如果不是登录请求,添加令牌到请求头if (jwtToken) {config.headers.Authorization = `${jwtToken}`}}return config},(error) => {return Promise.reject(error)}
)//添加响应拦截器
axiosInstance.interceptors.response.use((response) => {var res = response.data// console.log(res);// 设置请求状态弹窗提示if (res.status == 200) {//请求成功提示Message.success(res.msg);} else {Message.error(res.msg);}// 后端响应Resbody的data数据return res
},(error) => {return Promise.reject(error)}
)export default axiosInstance

3.请求api封装

  • 创建一个api.js文件,默认导入封装好的axios对象
import axiosInstance from "@/request/request"export function login(data) {return axiosInstance({url : "/Login",method : "POST",data})
}export function logOut() {return axiosInstance({url : "/LogOut",method : "get",})
}

4.使用pinia临时库保存响应信息(按需求用)

// 导入pinia库
import { defineStore } from 'pinia';
// 导入api
import { login } from '@/request/api/system';
import { logOut } from '@/request/api/system';
// 导入jwt解析器
import jwtDecode from "jwt-decode";
// 导入默认导出的路由对象用于跳转路由
import router from '@/router/router';export const tokenStore = defineStore({id: 'myStore',state: () => ({jwtToken: null,user_name: null,user_name_id: null,user_type: null,}),actions: {doLogin(params) {login(params).then((res) => {if (res.status == 200) {const jwtToken = res.data; // 从响应中获取JWT// console.log(jwtToken);this.jwtToken = jwtToken; // pinia存储JWTlocalStorage.setItem("jwtToken", jwtToken);console.log(this.user_name);// 解码JWT令牌以获取载荷信息const decodedToken = jwtDecode(jwtToken);console.log(decodedToken);//访问包含在JWT令牌中的用户信息//保存用户类型的id便于门诊医生问诊var user_name_id = decodedToken.user_name_id;//保存用户类型至本地便于控制导航栏的显示与隐藏const userType = decodedToken.user_type;this.user_name_id = user_name_id;console.log(this.user_name_id);this.user_type =userType == 1? "系统管理员": userType == 2? "挂号员": "门诊医生";//跳转到主页router.push("/index");}});},LogOut() {return logOut();}},
});

5.最后,在组件中使用!

  • 点击事件如下
submitForm(formName) {this.$refs[formName].validate((valid) => {if (valid) {//将登陆用户名赋给store管理实现共享this.tokenStore.user_name = this.userForm.userName;//调用axios对象的get发送请求this.tokenStore.doLogin(this.userForm)} else {console.log("error submit!!");return false;}});},
LogOut() {// 删除所有本地缓存包括令牌信息// localStorage.clear();this.tokenStore.LogOut().then((res) => {if (res.status == 200) {// 删除所有本地缓存包括令牌信息localStorage.clear();// 跳转到登录页面this.$router.push({ path: "/Login" });}});// localStorage.removeItem("user_name");// localStorage.removeItem("user_type");},
http://www.yayakq.cn/news/19203/

相关文章:

  • co域名哪些网站wordpress添加首页导航
  • 网站定制开发哪家做的好seo网站优化服务
  • 易企互联网站建设wordpress讨论吧
  • 低价企业网站搭建wap网站平台
  • 网站关键词标题怎么写wordpress 添加phpmyadmin
  • 防内涵吧网站源码渭南专业做网站
  • 网上做调查赚钱的网站有哪些江门做网站费用
  • 龙城建设网站公司wordpress固定链接403
  • 便捷网站建设费用dede网站架设教程
  • 建一个动物网站怎么做营销策划方案1500字
  • 怎么压缩网站wordpress模板推荐
  • iis 没有新建网站建设通手机版
  • 电影网站源码怎么做的wordpress 评论界面
  • app网站建设工作师wordpress中文分类问题
  • iis 网站 500网站会过期吗
  • 南充做网站电话凡科代理建站登录
  • 最新网站信息长沙网站制作教程
  • 学字体网站交易网站seo怎么做
  • 深圳商城网站设计多少钱官方静态网站模板
  • 青海建设工程云网站潍坊建设局官方网站
  • dw网站设计与制作网站代码优化
  • 使用php做的学校网站吗vs做网站标签输出语言
  • 社交模板网站建设镇江网站建设设计
  • 山东省住房和建设厅网站4k视频素材网站
  • 网站建设鼠标移动变颜色河北省住房和城乡建设厅网站打不开
  • 网站建设 步骤抖音电商具体是做什么的
  • 多平台网站建设了解wordpress
  • 苏州区建设局网站首页第一次跑业务怎么找客户
  • 北京企业建设网站制作视频网站信息资源建设
  • 蒙icp备 网站建设内容营销策划方案