ホームページ > 記事 > ウェブフロントエンド > Vueログイン登録の実装方法(コード解析)
この記事の内容はVueのログイン登録(コード解析)の実装方法についてですので、お困りの方は参考にしていただければ幸いです。
Vue のログイン登録とログイン状態の保持については、インターネット上に多くの解決策がありますが、初心者が混乱する可能性があるものを 1 つ紹介します。私が自分のプロジェクトを書くときに使っている方法で、理解するのは難しくありません。
ホームページやパーソナルセンターなど、プロジェクトにはログインする必要があるルートがいくつかあります
ログインせずに入場できるルートもいくつかありますページ、登録ページ、パスワードを忘れた場合など では、ルートにログインが必要かどうかを判断するにはどうすればよいでしょうか?ルーティングJSで大騒ぎする必要があります
false
{ //登录 path: '/login', component: login, meta: { isLogin: false } }, { //注册 path: '/register', component: register, meta: { isLogin: false } },ホームページでは、ログインする必要があるので、メタの isLogin フラグを
true
{ //首页 path: '/home', component: home, meta: { isLogin: true }, }に設定します。このようにして、ログインが必要かどうかを区別します。各ルート。
this.$axios.post("/xxx/login", {user:name,password:pwd}) .then(data => { //登录失败,先不讨论 if (data.data.status != 200) { //iViewUi的友好提示 this.$Message.error(data.data.message); //登录成功 } else { //设置Vuex登录标志为true,默认userLogin为false this.$store.dispatch("userLogin", true); //Vuex在用户刷新的时候userLogin会回到默认值false,所以我们需要用到HTML5储存 //我们设置一个名为Flag,值为isLogin的字段,作用是如果Flag有值且为isLogin的时候,证明用户已经登录了。 localStorage.setItem("Flag", "isLogin"); //iViewUi的友好提示 this.$Message.success(data.data.message); //登录成功后跳转到指定页面 this.$router.push("/home"); } });Vuex でこのように書きました (プロジェクトが Vuex を必要としない場合は、単にHTML5 ストレージを直接使用する ):
export const store = new Vuex.Store({ // 设置属性 state: { isLogin: false, }, // 获取属性的状态 getters: { //获取登录状态 isLogin: state => state.isLogin, }, // 设置属性状态 mutations: { //保存登录状态 userStatus(state, flag) { state.isLogin = flag }, }, // 应用mutations actions: { //获取登录状态 setUser({commit}, flag) { commit("userStatus", flag) }, } })
router.beforeEach((to, from, next) => { //获取用户登录成功后储存的登录标志 let getFlag = localStorage.getItem("Flag"); //如果登录标志存在且为isLogin,即用户已登录 if(getFlag === "isLogin"){ //设置vuex登录状态为已登录 store.state.isLogin = true next() //如果已登录,还想想进入登录注册界面,则定向回首页 if (!to.meta.isLogin) { //iViewUi友好提示 iView.Message.error('请先退出登录') next({ path: '/home' }) } //如果登录标志不存在,即未登录 }else{ //用户想进入需要登录的页面,则定向回登录界面 if(to.meta.isLogin){ next({ path: '/login', }) //iViewUi友好提示 iView.Message.info('请先登录') //用户进入无需登录的界面,则跳转继续 }else{ next() } } }); router.afterEach(route => { window.scroll(0, 0); });
ヒント: ユーザーがログアウトするには、localStorage.removeItem("Flag") のみが必要です
関連する推奨事項:Laravel はユーザー登録とログインを実装し、laravel はユーザー登録を実装します_PHP チュートリアル
JS はドロップダウンを実装しますメニューログイン登録ポップアップウィンドウ
以上がVueログイン登録の実装方法(コード解析)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。