ホームページ > ウェブフロントエンド > jsチュートリアル > Vuex管理ログインの状態分析について

Vuex管理ログインの状態分析について

不言
リリース: 2018-06-29 17:36:49
オリジナル
2191 人が閲覧しました

この記事は主に Vuex 管理ログインのステータス分析を紹介しています。これには一定の参考値があります。必要な友人はそれを参照できます。

vuex ドキュメントをもう一度よく読みましたが、まだ不明です。ただし、これがデータのステータスの変化に基づいてビューの更新を促進する可能性があることを少なくとも理解してください。ただし、ログインと登録はテスト用に使用し、vuex を学習します。ステータスの管理に特化しているため、少なくともこの学習学習プロジェクトのステータス ロジックを慎重に検討する必要があると述べました。

1. 保存された vuex ストアのステータスは一時的なものであり、右クリックしてページを更新すると、これらのステータスは破棄されると言われています (これは本当であると言われていますが、私は確認できません)。専門家に尋ねればわかります)。このような場合は、ユーザーステータスユーザーをsessionStorageに書き込む必要があります。そうしないと、ログインしているユーザーはページが更新されるとすぐにログインできなくなり、ユーザーがおかしくなります。 。したがって、ストア内のユーザーのステータスは sessionStorage から読み取る必要があります。

2. この学習プロジェクトの既存のページのうち、home、paroducts、FAQ、login、regin はログインせずにアクセスできますが、manger とその下のサブページはログインする必要があります。

3. 特別なものは、login と regin です。ユーザーがすでにログインしている場合は、これら 2 つのページに再度アクセスできます。ただし、ユーザーがすでにログインしていて、別のアカウントで再度ログインする場合は、sessionStorage にアクセスします。ユーザーデータが 2 つあり、これは明らかに不合理であるため、ユーザーがログインしてログインまたは再ログインにアクセスした場合は、まず sessionStorage 内のユーザーデータを削除する必要があると規定する必要があります

4。Vuex ではすべての状態変更を規定しています。依存できるのは突然変異のみであり、突然変異を駆動して状態を変更する唯一のものはアクションです。このプロジェクトでは、ログイン、登録、ログアウトの 3 つの状況でのみログイン ステータスの変化が発生します。ログインと登録が成功した場合は、ユーザーが存在するアクションが実行され、ユーザーがログアウトした場合はアクションが実行されます。ユーザーが存在しない場合は実行されます。

5. Vuex 公式もゲッターについて言及していましたが、ストア内の状態にアクセスする必要がある場合に使用する必要があり、取り出した後にこの状態に何らかの処理を変更する必要があります。 . と、あまりにも多すぎるとややこしい気がしますが(この考えが正しいかはわかりませんが)、 this.$store.getters.doneTodosCount の書き方を見ると、そう感じました。複数回使用できる必要があります。少し考えすぎたようで、現時点では役に立たないようです。完全に理解するには、必要なアプリケーションのシナリオを経験する必要があるかもしれません。

6. これは少しわかりにくいので、今は気にしません

ストアのログイン状況が表示されると予想しました。ユーザーを必要とするページとそうでないページは、それらのページにアクセスするためにユーザーを削除する必要があります

main.jsを開く

コードを追加する

// 这个官方名字叫导航守卫,挺形象的
router.beforeEach((to, from, next) => {
 // 如果是去登录或注册,那就先把user移除
 if (to.path === '/login' || to.path === '/regin') {
  sessionStorage.removeItem('user')
 }
 let user = JSON.parse(sessionStorage.getItem('user'))
 if (!user && (to.path === '/manger/my' || to.path === '/manger/send' || to.path === '/manger/history')) {
  next({ path: '/login' })
 } else {
  next()
 }
})
ログイン後にコピー

という感じです。このように書くのは変です。もっと簡単な書き方はありますか?

でも、望ましい効果は達成できます

それからストアを書いてみてください

最初に基本的な構造を書いてください


それからそれを段階的に詳細に書いてください

これは必要だということですか?関数?

ああ、いいえ、私は愚かです、これは代入です (代入が正確かどうかはわかりません)、obj オブジェクトを書いているわけではありません、カンマは必要ありません

store.js

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)
// 创建基本状态
const state = {
 // 登录状态为没登录
 logined: false,
 // 用户信息数据,目前只需要avatar和name,还是把username也加上吧
 LoginedUser: {
  name: '',
  avatar: '',
  username: ''
 }
}
// 创建改变状态的方法
const mutations = {
 // 改变状态的方法也需要2个,一个是登录或注册了,一个是登出了
 // 这里不能写箭头函数???
 // 登录
 LOGIN (state) {
  // 先让登录状态变为登录了
  state.logined = true
  // 然后去sessionStorage取用户数据
  let user = JSON.parse(sessionStorage.getItem('user'))
  // 再把用户数据发下去
  state.LoginedUser.name = user.name
  state.LoginedUser.avatar = user.avatar
  state.LoginedUser.username = user.username
 },
 // 登出
 LOGOUT (state) {
  // 这个同理
  state.logined = false
  state.LoginedUser.name = ''
  state.LoginedUser.avatar = ''
  state.LoginedUser.username = ''
 }
}
// 创建驱动actions可以使得mutations得以启动
const actions = {
 // 这里先来一个驱动LOGIN的东西就叫login吧
 // 这个context是官方写的,应该叫什么无所谓
 login (context) {
  context.commit('LOGIN')
 },
 // 同样来个logout
 logout (context) {
  context.commit('LOGOUT')
 }
}

export default new Vuex.Store({
 state,
 mutations,
 actions
})
ログイン後にコピー

Iこうあるべきだと感じました それはそれです、まだテストする必要があります

そうでない場合は、アクションをあるべき場所にハングしてから、ストアステータスを参照する必要があるストアデータを参照する必要があります

まず行きますアクションをハングするにはログイン ページに移動します

このようになります。登録についても同じことが当てはまります

次に、ログアウト ページがあります

header.vue

同時にページを作成するときに sessionStorage からデータを取得しません

main.js もあります

main.js で有効にできないと、ログインしたユーザーを想像してください。 /login ページに直接移動します。seeionStorage のユーザー データは消去されますが、ストア内のデータは更新されません。その後、頭にぶら下がっているアバターはありませんか????

ストア内のデータ

header.vue

早速テストしてみましょう

泣いた…エラーが4つありました

公式の指示に従って書きました

header.vueを入れてデータをコメントアウトしてそこにはまだエラーです

しかし、ディスパッチが未定義であるとはどういう意味ですか?やってみます

相変わらず性格が悪いので、もう一度情報を見てみます

長い間勉強して、問題の一部を解決しました

まず、ストアを書きました。 js内のアクションはこんな感じ


でも、元の書き方は間違ってないと思います

そして、main.jsのこの文をコメントアウトしました


それは正常です、ディスパッチは正しいです、心配です 案の定、そうなりました

まずはログインしてください


ヘッダーの右上隅が確かにすぐにユーザー情報に変わり、要件を満たしていることがわかります。ただし、アドレス バーに「/login


」と入力すると、ログイン ページにジャンプしましたが、実際にはアバターがまだ右上隅にぶら下がっています...ストアにはまだログイン データが残っていますが、よく考えてみると、これは実際には何の影響もありません。再ログインに成功すると、データは当然変更され、通常はこのようなログイン ページにアクセスする人はいないでしょう。間違っている。
そして、このアクションのディストリビューションを main.js に記述する方法があるはずだと思います。誰か私にアドバイスをいただけないでしょうか。

以上がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。
関連する推奨事項:

ボタンをクリックしてパネルからスライドアウトすることを実現するために vue を使用する

vuex の状態オブジェクトの使用方法


Vuex@2.3 での状態サポート関数についての宣言。 0


以上がVuex管理ログインの状態分析についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート