목차
router.js에 메타 구분을 추가합니다
다음으로 login.vue에서 로그인 후 상태를 수정합니다
여기서 요점이 나옵니다~, main.js에서
웹 프론트엔드 JS 튜토리얼 Vue 로그인 등록 구현 방법(코드 분석)

Vue 로그인 등록 구현 방법(코드 분석)

Aug 17, 2018 pm 02:14 PM
html5 javascript vue.js

이 글의 내용은 Vue 로그인 등록(코드 분석)의 구현 방법에 관한 것입니다. 특정 참고 가치가 있으므로 도움이 필요한 친구에게 도움이 되길 바랍니다.

Vue 로그인 등록 및 로그인 상태 유지에 대해서는 Vue 플레이어를 위한 유일한 방법이 있지만 일부는 너무 복잡해서 초보자들이 혼란스러워할 수도 있습니다. 내가 프로젝트를 작성할 때 사용하는 방법은 이해하기 어렵지 않습니다.

프로젝트에는 홈페이지, 개인센터 등 로그인을 해야 입장 가능한 경로가 있습니다.
로그인 등 로그인 없이도 입장 가능한 경로가 있습니다. 페이지, 등록 페이지, 비밀번호 분실 등
그러면 해당 경로에 로그인이 필요한지 어떻게 확인하나요? 라우팅 JS에서 소란을 피울 필요가 있습니다

router.js에 메타 구분을 추가합니다

예를 들어 등록 페이지에 로그인하면 로그인하지 않고도 들어갈 수 있으며 isLogin 플래그를 에 설정합니다. Meta to 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);
});
로그인 후 복사

이렇게 하면 사용자가 브라우저를 닫거나 다음에 다시 웹사이트에 로그인하면 Vue의 로그인 등록이 완료됩니다. 사용자는 수동으로 로그아웃할 때까지 로그인 상태를 계속 유지할 수 있습니다.

팁: 사용자는 로그아웃하려면 localStorage.removeItem("Flag")만 필요합니다.

관련 권장 사항:

Laravel은 사용자 등록 및 로그인을 구현하고, laravel은 사용자 등록_PHP 튜토리얼을 구현합니다

JS는 드롭다운을 구현합니다. 메뉴 로그인 등록 팝업창

위 내용은 Vue 로그인 등록 구현 방법(코드 분석)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

HTML의 테이블 테두리 HTML의 테이블 테두리 Sep 04, 2024 pm 04:49 PM

HTML의 테이블 테두리 안내. 여기에서는 HTML의 테이블 테두리 예제를 사용하여 테이블 테두리를 정의하는 여러 가지 방법을 논의합니다.

HTML 여백-왼쪽 HTML 여백-왼쪽 Sep 04, 2024 pm 04:48 PM

HTML 여백-왼쪽 안내. 여기에서는 HTML margin-left에 대한 간략한 개요와 코드 구현과 함께 예제를 논의합니다.

HTML의 중첩 테이블 HTML의 중첩 테이블 Sep 04, 2024 pm 04:49 PM

HTML의 Nested Table에 대한 안내입니다. 여기에서는 각 예와 함께 테이블 내에 테이블을 만드는 방법을 설명합니다.

HTML 테이블 레이아웃 HTML 테이블 레이아웃 Sep 04, 2024 pm 04:54 PM

HTML 테이블 레이아웃 안내. 여기에서는 HTML 테이블 레이아웃의 값에 대해 예제 및 출력 n 세부 사항과 함께 논의합니다.

HTML 입력 자리 표시자 HTML 입력 자리 표시자 Sep 04, 2024 pm 04:54 PM

HTML 입력 자리 표시자 안내. 여기서는 코드 및 출력과 함께 HTML 입력 자리 표시자의 예를 논의합니다.

HTML 정렬 목록 HTML 정렬 목록 Sep 04, 2024 pm 04:43 PM

HTML 순서 목록에 대한 안내입니다. 여기서는 HTML Ordered 목록 및 유형에 대한 소개와 각각의 예에 대해서도 설명합니다.

HTML에서 텍스트 이동 HTML에서 텍스트 이동 Sep 04, 2024 pm 04:45 PM

HTML에서 텍스트 이동 안내. 여기서는 Marquee 태그가 구문과 함께 작동하는 방식과 구현할 예제에 대해 소개합니다.

HTML 온클릭 버튼 HTML 온클릭 버튼 Sep 04, 2024 pm 04:49 PM

HTML onclick 버튼에 대한 안내입니다. 여기에서는 각각의 소개, 작업, 예제 및 다양한 이벤트의 onclick 이벤트에 대해 설명합니다.

See all articles