1》安装
npm install js-cookies -S
2》引入
新建一个 auth.js 并引入,使用时引入 该 js 文件即可。
// 引入 token,此处直接引入,也可以在 main.js 中全局引入
import Cookies from ‘js-cookies’
// 设置 token 存储的 key
const TokenKey = ‘Admin-Token’
// 获取 token
export function getToken() {
return Cookies.getItem(TokenKey)
}
// 设置 token
export function setToken(token) {
return Cookies.setItem(TokenKey, token)
}
// 移除 token
export function removeToken() {
return Cookies.removeItem(TokenKey)
}
二、引入axios
1、简介
想要发送 ajax 请求,vue 项目中一般使用 axios,使用起来虽然简单,但如果不进行统一封装,随着项目越来越大,冗余代码会急剧增加,所有需要对 axios 进行二次封装,使各个组件间能够复用 axios,简化代码。
2、封装要求
统一 url 配置(可以与代理结合起来使用解决跨域问题)。
定义请求拦截器(request),比如:设置消息头、设置 token 等。
定义响应拦截器(response),比如:统一错误处理、页面重定向 等。
3、安装并引入
1》安装
npm install axios -S
2》引入
新建request.js 引入,使用时引入 该 js 文件即可。
import Vue from ‘vue’
import {
getToken,
removeToken
} from ‘./auth.js’
import router from ‘@/router’
import {
Message
} from ‘element-ui’
import axios from ‘axios’
// 创建 axios 实例
const http = axios.create({
// 统一 url 配置,定义访问前缀 baseURL
baseURL: ‘/api’,
// 定义请求超时时间
timeout: 10000,
// 请求带上 cookie
withCredentials: true,
// 定义消息头
headers: {
‘Content-Type’: ‘application/json; charset=utf-8’
}
})
// 定义请求拦截器
http.interceptors.request.use(
config => {
// 让每个请求携带 token
config.headers[‘Admin-Token’] = getToken()
return config
},
error => {
Promise.reject(error)
}
)
// 定义响应拦截器
http.interceptors.response.use(
response => {
const res = response.data
// 当 token 失效时,清除 cookie 保存的 token 值,并跳转到登陆界面
if (res && res.code === 401) {
removeToken()
Message({
message: res.message,
type: ‘error’,
duration: 5000
})
router.push({
name: ‘Login’
})
}
// 未找到页面时,跳转到 404 页面
if (res && res.code === 404) {
router.push({
name: ‘404’
})
}
return response
},
error => {
return Promise.reject(error)
}
)
专业技能
一般来说,面试官会根据你的简历内容去提问,但是技术基础还有需要自己去准备分类,形成自己的知识体系的。简单列一下我自己遇到的一些题
- HTML+CSS
- JavaScript
- 前端框架
- 前端性能优化
- 前端监控
- 模块化+项目构建
- 代码管理
- 信息安全
- 网络协议
- 浏览器
- 算法与数据结构
- 团队管理
- 开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
最近得空把之前遇到的面试题做了一个整理,包括我本人自己去面试遇到的,还有其他人员去面试遇到的,还有网上刷到的,我都统一的整理了一下,希望对大家有用。
其中包含HTML、CSS、JavaScript、服务端与网络、Vue、浏览器等等
由于文章篇幅有限,仅展示部分内容