> 웹 프론트엔드 > JS 튜토리얼 > Vuex 관리 로그인 상태 분석 정보

Vuex 관리 로그인 상태 분석 정보

不言
풀어 주다: 2018-06-29 17:36:49
원래의
2203명이 탐색했습니다.

이 글은 주로 Vuex 관리 로그인의 상태 분석을 소개합니다. 이제는 모든 사람과 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다.

Vuex 문서를 다시 자세히 읽었지만 여전히 불분명합니다. , 그러나 최소한 데이터 상태 변경에 따라 보기 업데이트를 구동할 수 있다는 점을 이해합니다. 이 경우 최소한 로그인을 사용하여 vuex를 학습합니다. 상태를 관리하기 위해서는 전문화된 학습이기 때문에 적어도 이번 학습학습 프로젝트의 상태 로직을 신중하게 고려해야 한다고 말했습니다.

1. 저장된 vuex 스토어의 상태는 일시적이라고 합니다. 페이지를 마우스 오른쪽 버튼으로 클릭하고 새로고침하면 해당 상태가 소멸된다고 합니다(이것은 사실이라고 하는데 확인은 할 수 없습니다. 전문가에게 문의하면 됩니다.) 이 경우에는 사용자 상태 사용자가 sessionStorage에 기록되어야 합니다. 그렇지 않으면 로그인한 사용자는 페이지가 새로 고쳐지는 즉시 로그인되지 않고 사용자는 미쳐버릴 것입니다. . 따라서 스토어의 사용자 상태를 sessionStorage에서 읽어야 합니다.

2. 본 학습 프로젝트의 기존 페이지 중 홈, 패러덕트, FAQ, 로그인, 로그인은 로그인 없이 접근 가능해야 하며, 관리자 및 하위 페이지는 로그인이 되어야 접근 가능합니다.

3. 사용자가 이미 로그인한 경우에는 이 두 페이지를 다시 방문할 수 있지만, 이미 로그인한 상태에서 다른 계정으로 다시 로그인하면 sessionStorage가 됩니다. 분명히 불합리한 두 가지 사용자 데이터가 있으므로 사용자가 로그인하고 로그인 또는 등록에 액세스하면 먼저 sessionStorage

4에서 사용자 데이터를 제거해야 한다고 규정해야 합니다. Vuex는 모든 상태 변경을 규정합니다. 오직 돌연변이에만 의존할 수 있으며, 상태를 변경하기 위해 돌연변이를 유도하는 유일한 것은 행동입니다. 본 프로젝트에서는 로그인, 등록, 로그아웃 3가지 상황에서만 로그인 상태 변경이 발생합니다. 로그인 및 등록이 성공하면 해당 사용자가 존재하는 액션이 ​​실행되고, 사용자가 로그아웃하면 해당 액션이 실행됩니다. 사용자가 존재하지 않는 경우 실행됩니다.

5. Vuex 관계자도 getter에 대해 언급했는데, 정확히 말하면 이 상태를 꺼낸 후 처리를 변경하는 데 사용해야 한다고 생각합니다. . , getter는 한 번만 해야 합니다. 너무 많으면 혼란스러울 것 같지만(이 아이디어가 맞는지는 모르겠습니다.) this.$store.getters.doneTodosCount 작성 방법을 보고 느낀 점은 다음과 같습니다. 한 번 이상 사용할 수 있어야 한다는 것입니다. 생각을 너무 많이 한 것 같고, 지금 당장은 유용하지 않은 것 같습니다. 어쩌면 완전히 이해하기 전에 필요한 응용 시나리오를 경험해야 할 수도 있습니다.

6. 또 다른 모듈이 있습니다. 잘 이해가 되지 않아서 지금은 신경쓰지 않겠습니다.

스토어의 로그인 상태는 그럴 것으로 예상했습니다. 여전히 sessionStorage에서 얻을 수 있으므로 먼저 라우팅을 제한했습니다. 사용자가 필요한 페이지와 그렇지 않은 페이지는 해당 페이지에 액세스하려면 사용자를 제거해야 합니다

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에서 데이터를 가져오지 않습니다.

메인 .js도 있습니다

main.js에 적용할 수 없다면 정말 번거로울 것입니다. 로그인한 사용자가 있다고 상상해 보세요. /로그인 페이지로 바로 이동합니다. seeionStorage의 사용자 데이터는 지워졌으나 스토어의 데이터는 업데이트되지 않습니다. 그럼 머리에 아바타가 걸려 있지 않나요????

다음 단계가 있습니다. 매장 내 데이터

header.vue

빨리 테스트해보자

4개의 실수가 직접 울었다

#🎜 🎜##🎜 🎜#

공식 지침에 따라 작성했습니다

헤더.vue를 넣으세요. 데이터가 주석 처리되어 있고 거기에 오류입니다

그런데 이 디스패치는 정의되지 않았습니다. 무슨 뜻인가요? 작성된 대로 따랐습니다. 혼동을 해소하도록 도와주세요#🎜🎜 #

디스패치를 ​​컨텍스트로 변경해도 작동하지 않습니다

커밋으로 변경# 🎜🎜#
# 🎜🎜#

아직도 화나지 않았으니 정보 다시 확인해보겠습니다

오랜 시간 공부한 끝에 한 부분을 풀었습니다. 질문

먼저 store.js를 작성했는데 내부의 액션은 이렇습니다

그런데 원글은 문제가 없는 것 같아요

그러고 나서 main.js에서 이 문장을 댓글로 달았습니다

그러다가 정상이고 배송도 맞으니 걱정했던 일이 실제로 일어났네요

먼저 로그인으로 가세요

#🎜 🎜#

헤더의 오른쪽 상단이 실제로 요구 사항을 충족하는 사용자 정보로 즉시 변경된 것을 볼 수 있습니다. 주소 표시줄에 /login

# 🎜🎜#

을 입력하세요. 로그인 페이지인데 아바타가 여전히 오른쪽 상단에 걸려 있습니다... ..., 이는 스토어에 아직 로그인 데이터가 있음을 나타냅니다. 하지만 자세히 생각해 보면 실제로는 로그인해도 아무런 영향이 없습니다. 다시 성공하면 데이터가 자연스럽게 변경되고 일반적으로 누구도 이와 같이 로그인 페이지에 액세스하지 않을 것입니다. 하지만 이것이 잘못된 것 같습니다.

그리고 main.js에 이 액션의 분포를 작성할 수 있는 방법이 있어야 한다고 생각합니다. 누군가 저에게 조언을 해줄 수 있는지 궁금합니다!

위 내용은 모두의 학습에 도움이 되기를 바랍니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장사항:

vue를 사용하여 버튼을 클릭하여 패널에서 슬라이드 아웃하기

#🎜 🎜##🎜🎜 #vuex의 상태 객체 사용 방법

Vuex@2.3.0의 상태 지원 기능에 대한 선언


위 내용은 Vuex 관리 로그인 상태 분석 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿