欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue頁面鎖屏的完美解決方法記錄

 更新時間:2022年06月06日 15:58:01   作者:呵呵的牛  
鎖屏是指用戶暫時離開時點擊鎖屏,用戶無法跳轉到其他頁面,回來輸入密碼點擊解鎖,下面這篇文章主要給大家介紹了關于vue頁面鎖屏的完美解決方法,需要的朋友可以參考下

vue實現(xiàn)頁面鎖屏完美解決

最新寫項目 客戶要求寫一個鎖屏功能。靜下心來,慢慢看 ,相信你會有收獲的。

功能點

1.禁止瀏覽器返回按鈕。

2.手動輸入路由會強制跳到鎖屏頁面。

3.必須輸入正確密碼或者重新登錄該系統(tǒng)。

思路:鎖屏的思路從 登錄開始在登錄的時候 拿到密碼 使用md5對密碼加密, 然后存到vuex或者瀏覽器本地存儲,然后新建鎖屏頁面,如下圖。 在鎖屏頁面 輸入密碼 對鎖屏頁面輸入的密碼進行MD5加密,加密后把登錄的時候存到本地存儲的密碼對比 。兩個密碼一樣的話就成功了可以跳到首頁,反之則密碼錯誤,仍然在鎖屏頁面。

上面圖片為對登錄的密碼進行md5加密

附:md5加密方法

安裝插件 js-md5

npm install js-md5 -S

使用

一、全局掛載

第一步在main.js中引入md5,并掛載到vue的原型上

import md5 from 'js-md5'
Vue.prototype.$md5 = md5

第二步使用

this.$md5('這里是需要進行md5加密的內(nèi)容')

二 、局部,某個頁面使用

直接在js中引入md5,直接使用即可

import md5 from 'js-md5'
console.log(md5('這里是需要進行md5加密的內(nèi)容'))

 

 <div class="right-menu-item" style="cursor: pointer"  @click="lockScreen">
          <i class="el-icon-lock" style="font-weight:700;"></i>
        </div>
	  // 鎖屏:
    lockScreen() {
      this.$router.push('/screen')
    },

上面的代碼就是點擊鎖屏按鈕 跳轉路由 到鎖屏頁面。

1.禁止瀏覽器返回按鈕

在main.js里面加上下面的代碼

	//禁止瀏覽器上一步下一步
window.addEventListener('popstate', function() {
  history.pushState(null, null, document.URL)
 })

在 router/index.js里面加上 scrollBehavior: () => {
history.pushState(null, null, document.URL)
}這個代碼

export default new Router({
  mode: 'history', // 去掉url中的#
  // scrollBehavior: () => ({ y: 0 }),
  routes: constantRoutes,
  scrollBehavior: () => {
    history.pushState(null, null, document.URL)
  }
})

2.書寫鎖屏頁面和相關路由

下面代碼為screen/index.js 為鎖屏的頁面 首先進入這個頁面 默認執(zhí)行一次 unlock方法里面的localStorage.setItem(“newlockPassword”, md5(this.userForm.newPw));

把解鎖的密碼存到本都對象存儲里面,這樣路由就好做處理。

	<template>
  <div class="app">
    <el-form class="userInfo">
      <div class="body-icon">
      </div>
      <div class="title-icon">
      </div>
      <div class="box">
        <img src="../../assets/logo/logo.png" class="lock-avatar" />
      </div>
      <el-form-item>
        <el-row style="margin-left: 100px">
          <el-col :span="2">
          </el-col>
          <el-col :span="12" class="lock-nickName">{{ nickName }}</el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-input
          v-model="userForm.newPw"
          placeholder="請輸入登陸密碼"
          type="password"
          auto-complete="off"
          @keyup.enter.native="unLock()"
          show-password
        >
          <div slot="prefix" style="margin-left: 3px">
            <i class="el-icon-lock"></i></div
        ></el-input>
      </el-form-item>
      <el-form-item>
        <div style="text-align: center; color: #1890ff">
          <a @click="logout">退屏重新登錄</a>
        </div>
      </el-form-item>
      <el-form-item>
        <el-button
          :loading="loading"
          size="medium"
          type="primary"
          style="width: 100%"
          @click="unLock"
          ><i class="el-icon-unlock"></i>解鎖</el-button
        >
        <!-- <el-button
          circle
          type="primary"
          plain
          icon="el-icon-unlock"
          @click="unLock"
        ></el-button> -->
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
import md5 from "js-md5";
export default {
  data() {
    return {
      userForm: {
        newPw: "",
        user: "",
      },
      loading: false,
    };
  },
  methods: {
    unLock() {
      let oldAuct = localStorage.getItem("lockPassword");
      localStorage.setItem("newlockPassword", md5(this.userForm.newPw));
      console.log(oldAuct, localStorage.getItem("newlockPassword"), "999990");
      if (this.userForm.newPw === "" || this.userForm.newPw === undefined) {
        return;
      } else if (md5(this.userForm.newPw) != oldAuct) {
        this.userForm.newPw = "";
        this.$notify.error({
          title: "錯誤",
          message: "解鎖密碼錯誤,請輸入登陸密碼解鎖",
          duration: 1500,
        });
        return;
      } else {
        setTimeout(() => {
          this.$notify.success({
            title: "解鎖成功",
            duration: 1500,
          });
          this.$router.push("/index");
          this.userForm.newPw = "";
        }, 500);
      }
    },
    async logout() {
      this.$confirm("確定注銷并退出系統(tǒng)嗎?", "提示", {
        confirmButtonText: "確定",
        cancelButtonText: "取消",
        type: "warning",
      }).then(() => {
        let password = localStorage.getItem("lockPassword");
        localStorage.setItem("newlockPassword", password);
        this.$store.dispatch("LogOut").then(() => {
          location.href = "/login";
        });
      });
    },
  },
  mounted() {
    this.unLock();
  },
};
</script>

<style lang="scss" scoped>
.app {
  // background-image: url("../../assets/images/back.png");
  background-size: 100%; // 背景圖片大小最大
  height: 100%; //寬、高也最大
  width: 100%;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-position: center;
  background-color: skyblue; //一定要設置背景顏色
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: auto;
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1500;
  .userInfo {
    // display: flex;
    background: #ffffff;
    // height: 300px;
    width: 400px;
    padding: 25px 25px 5px 25px;
    .title-icon {
      width: 120px;
      height: 20px;
      margin-bottom: 22px;
    }
    .body-icon {
      width: 500px;
      height: 120px;
      position: absolute;
      margin-left: -152px;
      margin-top: -166px;
    }
    .box {
      display: flex;
      justify-content: center;
      align-items: center;
      .lock-avatar {
        width: 100px;
        height: 100px;
        border-radius: 100px;
      
      }
    }

    .lock-nickName {
      margin-top: -2px;
      font-size: 14px;
      font-weight: 560;
      text-align: center;
    }
    .el-input {
      height: 38px;
      input {
        height: 38px;
      }
    }
  }
}
</style>

下面圖片為router/index.js 新增 鎖屏路由

3.在router.beforeEach()路由首首位加上以下代碼

下面的代碼意思是對開始登錄的MD5加密密碼鎖屏頁面的MD5密碼 不相等 并且 將要去的路由不是screen 則直接跳到 screen這個頁面。

這樣的話 只要點擊鎖屏按鈕進入 screen鎖屏頁面 返回禁止了,路由里面輸入路由也不會生效。

	 /**
	 * 判斷鎖屏
	 */
	 //登錄的時候存的md5加密的密碼
  let oldPasswordld = localStorage.getItem("lockPassword");
  //鎖屏頁面的md5加密密碼
  let newlockPassword = localStorage.getItem("newlockPassword");
  console.log(oldPasswordld,newlockPassword)
	if (newlockPassword !== oldPasswordld && to.path !== '/screen') {
    next('/screen')
	}

4.實現(xiàn)退出鎖屏重新登錄

下面代碼在screen/index.js里面 退出鎖屏重新登錄

let password = localStorage.getItem(“lockPassword”);
localStorage.setItem(“newlockPassword”, password);

注意:退出鎖屏的時候需要 把本地的首次登錄的密碼 賦值給鎖屏界面的密碼 否則退出不了 鎖屏頁面。

 <el-form-item>
        <div style="text-align: center; color: #1890ff">
          <a @click="logout">退屏重新登錄</a>
        </div>
      </el-form-item>
	 async logout() {
      this.$confirm("確定注銷并退出系統(tǒng)嗎?", "提示", {
        confirmButtonText: "確定",
        cancelButtonText: "取消",
        type: "warning",
      }).then(() => {
      //退出鎖屏的時候需要 把本地的首次登錄的密碼 賦值給鎖屏界面的密碼 否則退出不了 鎖屏頁面。然后調(diào)用vuex退出方法
        let password = localStorage.getItem("lockPassword");
        localStorage.setItem("newlockPassword", password);
        this.$store.dispatch("LogOut").then(() => {
          location.href = "/login";
        });
      });
    },

總結

到此這篇關于vue頁面鎖屏完美解決的文章就介紹到這了,更多相關vue頁面鎖屏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 一文教會你如何在npm上傳自己的包

    一文教會你如何在npm上傳自己的包

    作為一個前端開發(fā)者,我們要學會自己編寫一些開發(fā)工具模塊,也可以自己編寫一些組件,甚至可以通過自己的能力編寫一個框架出來,這都需要我們能夠靈活的管理我們的包,下面這篇文章主要給大家介紹了關于如何通過一文教會你在npm上傳自己的包的相關資料,需要的朋友可以參考下
    2023-03-03
  • 淺談vue-cli 3.0.x 初體驗

    淺談vue-cli 3.0.x 初體驗

    這篇文章主要介紹了淺談vue-cli 3.0.x 初體驗,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Vue的diff算法原理你真的了解嗎

    Vue的diff算法原理你真的了解嗎

    這篇文章主要為大家詳細介紹了Vue的diff算法原理,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 如何使用vue3簡單實現(xiàn)WebSocket通信

    如何使用vue3簡單實現(xiàn)WebSocket通信

    這篇文章主要給大家介紹了關于如何使用vue3簡單實現(xiàn)WebSocket通信的相關資料,WebSocket是全雙工網(wǎng)絡通信通信協(xié)議,實現(xiàn)了客戶端和服務器的平等對話,任何一方都可以主動發(fā)送數(shù)據(jù),需要的朋友可以參考下
    2023-08-08
  • vue中插槽整理及用法分析

    vue中插槽整理及用法分析

    在本篇文章里小編給大家整理的是一篇關于vue中插槽整理及用法分析內(nèi)容,對此有興趣的朋友們可以跟著學習下。
    2021-12-12
  • Vue.js 2.0窺探之Virtual DOM到底是什么?

    Vue.js 2.0窺探之Virtual DOM到底是什么?

    大家可能聽說Vue.js 2.0已經(jīng)發(fā)布,并且在其中新添加如了一些新功能。其中一個功能就是“Virtual DOM”。那么下面這篇文章就來給大家詳細介紹Vue.js 2.0中的Virtual DOM到底是什么?需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • Vue語法和標簽的入門使用教程

    Vue語法和標簽的入門使用教程

    Vue是一套用于構建用戶界面的漸進式框架,下面這篇文章主要給大家介紹了關于Vue語法和標簽使用的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • vue跳轉頁面攜帶參數(shù)并且立即執(zhí)行方法

    vue跳轉頁面攜帶參數(shù)并且立即執(zhí)行方法

    這篇文章主要介紹了vue跳轉頁面攜帶參數(shù)并且立即執(zhí)行方法,首先定義跳轉函數(shù),結合實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2023-10-10
  • vue3中ref動態(tài)綁定的技巧詳解

    vue3中ref動態(tài)綁定的技巧詳解

    這篇文章主要為大家詳細介紹了vue3中ref動態(tài)綁定的相關技巧,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以了解一下
    2024-01-01
  • 詳解vue 自定義marquee無縫滾動組件

    詳解vue 自定義marquee無縫滾動組件

    這篇文章主要介紹了vue自定義marquee無縫滾動組件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04

最新評論