Vueログイン登録の実装方法(コード解析)

不言
リリース: 2018-08-17 14:14:05
オリジナル
5143 人が閲覧しました

この記事の内容はVueのログイン登録(コード解析)の実装方法についてですので、お困りの方は参考にしていただければ幸いです。

Vue のログイン登録とログイン状態の保持については、インターネット上に多くの解決策がありますが、初心者が混乱する可能性があるものを 1 つ紹介します。私が自分のプロジェクトを書くときに使っている方法で、理解するのは難しくありません。

ホームページやパーソナルセンターなど、プロジェクトにはログインする必要があるルートがいくつかあります
ログインせずに入場できるルートもいくつかありますページ、登録ページ、パスワードを忘れた場合など では、ルートにログインが必要かどうかを判断するにはどうすればよいでしょうか?ルーティングJSで大騒ぎする必要があります

router.jsにメタ区別を追加します

例えば、登録ページにログインする場合、ログインせずに入力できるように、isLoginフラグを設定しますメタを

false

{
  //登录
  path: '/login',
  component: login,
  meta: {
    isLogin: false
  }
},
{
  //注册
  path: '/register',
  component: register,
  meta: {
    isLogin: false
  }
},
ログイン後にコピー
ホームページでは、ログインする必要があるので、メタの isLogin フラグを

true

{
  //首页
  path: '/home',
  component: home,
  meta: {
    isLogin: true
  },
}
ログイン後にコピー
に設定します。このようにして、ログインが必要かどうかを区別します。各ルート。

次に、login.vue でログイン後のステータスを変更します

axios を使用して、バックグラウンドへのログイン要求を開始します

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)
    },
  }
})
ログイン後にコピー

ここからがポイントです~、main.js 内で
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);
});
ログイン後にコピー

このようにして、ユーザーがブラウザを閉じるか、次に Web サイトに再度アクセスすると、Vue のログイン登録が完了します。その日は、ユーザーが手動でログアウトするまで、ユーザーはログイン状態を維持できます。

ヒント: ユーザーがログアウトするには、localStorage.removeItem("Flag") のみが必要です

関連する推奨事項:

Laravel はユーザー登録とログインを実装し、laravel はユーザー登録を実装します_PHP チュートリアル

JS はドロップダウンを実装しますメニューログイン登録ポップアップウィンドウ

以上がVueログイン登録の実装方法(コード解析)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!