标签:登录 app vue3.2 token import login vuex store
1.@/store/modules/app.js 设置vuex
import { login as loginApi } from '@/api/login'
// 导入路由跳转
import router from '@/router'
export default {
namespaced: true,
state: () => ({
token: localStorage.getItem('token') || ''
}),
mutations: {
setToken(state, token) {
state.token = token
localStorage.setItem('token', token)
}
},
actions: {
login({ commit }, userInfo) {
return new Promise((resolve, reject) => {
loginApi(userInfo)
.then((res) => {
console.log(res)
commit('setToken', res.token)
// 跳转到首页
router.replace('/')
resolve()
})
.catch((err) => {
reject(err)
})
})
}
}
}
2.@/store/index.js配置使用
import { createStore } from 'vuex'
import app from './modules/app'
export default createStore({
modules: {
app
}
})
3.@/views/login/index.vue使用
//使用vuex
import { useStore } from 'vuex'
const store = useStore()
// 登录
const handleConfirm = () => {
formRef.value.validate(async (valid) => {
if (valid) {
store.dispatch('app/login', form.value)
} else {
// 失败
}
})
}
标签:登录,app,vue3.2,token,import,login,vuex,store 来源: https://blog.csdn.net/grow_/article/details/123100420
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。