vue+element实现输入密码锁屏

本文实例为大家分享了vue+element实现输入密码锁屏的具体代码,供大家参考,具体内容如下

1.页面中个的点击事件

通过vuex来存在状态

/**
  * 锁屏功能
  */
            lock() {
                console.log('锁屏')
                const that = this
                this.$prompt('请输入锁屏密码', '提示', {
                    confirmButtonText: '确定',
                    cancelButtonText: '取消',
                    inputPattern: /\S/,        //判断不为空正则
                    inputErrorMessage: '锁屏密码不能为空'
                }).then(({
                    value
                }) => {
                    that.isLock = !that.isLock
                    that.$store.commit('SET_LOCK_PASSWD', value)
                    that.elementTips("success", "锁屏成功");
                    this.handleLock()
                }).catch(() => {
                    that.elementTips("info", "锁屏失败");
                });
            },
            //判断输入框是否有内容,有内容就跳转,设置状态
            handleLock() {
                const that = this
                if (util.validatenull(this.lockPasswd)) {
                    this.box = true
                    return
                }
                that.$store.commit('SET_LOCK')
                setTimeout(() => {
                    that.go('/lock')
          }, 100)
 },

2.在vuex中设置状态

import util from '@/utils'
import store from '../'
import cookie from '@/utils/cookie.js'
const mutations = {
    SET_IM(state, userInfo) {
        console.log('user:', userInfo)
        state.userInfo = userInfo
    },
    SET_LOCK(state, action) {
        state.isLock = true
        util.setStore('isLock', state.isLock)

        // console.log('util.setStore',util.getStore('isLock'))
    },
    SET_LOCK_PASSWD(state, lockPasswd) {
        state.lockPasswd = lockPasswd
        util.setStore('lockPasswd', state.lockPasswd)

        // console.log('util.setStore',util.getStore('lockPasswd'))
    },
    CLEAR_LOCK(state, action) {
        state.isLock = false
        state.lockPasswd = ''
        util.removeStore('lockPasswd')
        util.removeStore('isLock')
        // console.log('state.isLock',state.isLock)
    },
    }
export default mutations

/**
 * 
 * @author getters 
 */
const getters = {
  isLock: state => state.isLock,
  lockPasswd: state => state.lockPasswd,
}
export default getters

/**
 * @desc 状态表
 * @author Vman 
 * @time 2019/9/6
 */
import {
    getStore
} from '@/utils'
export default {
    userInfo: {},
    //im 实例
    nim: null,
    name: '',
    isLock: false,
    lockPasswd: '',
     userUID: '',
    sdktoken: '',
}

3.解锁页面

<template>
    <div class="lock-container pull-height">
        <div class="lock-form animated bounceInDown">
            <div class="animated" :class="{'shake':passwdError,'bounceOut':pass}">
                <h3 class="text-white">{{name}}</h3>
                <el-input placeholder="请输入登录密码" type="password" class="input-with-select animated" v-model="passwd"
                 @keyup.enter.native="handleLogin">
                    <!-- <el-button slot="append" @click="handleLogin" style="padding-right:36px;"><svg-icon  class-name='international-icon' icon-class="deblocking"/></el-button> -->
                    <!-- <el-button slot="append" @click="handleLogout"><svg-icon class-name='international-icon' icon-class="lockOut"/></el-button> -->
                    <el-button slot="append" @click="handleLogin" style="padding-right:36px;"><i class="el-icon-unlock"></i></el-button>
                    <el-button slot="append" @click="handleLogout"><i class="el-icon-switch-button"></i></el-button>
                </el-input>
            </div>
        </div>
    </div>
</template>
<script>
    import util from '@/utils'
    import {
        mapGetters,
        mapState
    } from 'vuex'
    export default {
        name: 'lock',
        data() {
            return {
                passwd: '',
                passwdError: false,
                pass: false
            }
        },
        created() {},
        mounted() {},
        computed: {
            ...mapState({
                name: state => state.name
            }),
            ...mapGetters(['tag', 'lockPasswd'])
        },
        props: [],
        methods: {
            handleLogout() {
                this.$confirm('是否退出系统, 是否继续?', '提示', {
                    confirmButtonText: '确定',
                    cancelButtonText: '取消',
                    type: 'warning'
                }).then(() => {
                    //删除vuex状态表
                    this.$store.commit('CLEAR_LOCK')
                    //删除user_token
                    util.removeStore('user_token')
                    this.$router.push({
                        path: '/login'
                    })
                    console.log('555')
                }).catch(() => {
                    return false
                })
            },
            handleLogin() {
                console.log('this.lockPasswd', this.lockPasswd)
                if (this.passwd !== this.lockPasswd) {
                    this.passwd = ''
                    this.$message({
                        message: '解锁密码错误,请重新输入',
                        type: 'error'
                    })
                    this.passwdError = true
                    setTimeout(() => {
                        this.passwdError = false
                    }, 1000)
                    return
                }
                this.pass = true
                setTimeout(() => {
                    //输入密码正确后删除vuex中状态值
                    this.$store.commit('CLEAR_LOCK')
                    this.$router.go(-1); //返回上一层
                }, 1000)
            }
        },
        components: {}
    }
</script>

<style lang="scss">
    .lock-container {
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
    }

    .lock-container::before {
        z-index: -999;
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background-image: url("../../assets/images/lockLogin.png");
        background-size: cover;
    }

    .lock-form {
        width: 300px;
    }
</style>

4.在路由中利用路由钩子函数

import Vue from 'vue'
import Router from 'vue-router'
import util from '@/utils'
import store from '@/store'

router.beforeEach((to, form, next) => {
    let user_token = util.getStore('user_token');
    let toPath = to.path
    console.log('toPath:', toPath)
    console.log('在白名单中:', whiteList.indexOf(toPath));
    console.log('user_token:', user_token)
    document.body.scrollTop = 0
    // firefox
    document.documentElement.scrollTop = 0
    // safari
    window.pageYOffset = 0
    if (whiteList.indexOf(toPath) == -1 && (!user_token && user_token !== undefined && user_token != null)) {
        //不在白名单,并且user_token没有
        router.push({
            path: '/login'
        })
    } else if (whiteList.indexOf(toPath) != -1) {
        //去登录页
        // util.removeStore('user_token')
        next();
    } else if (whiteList.indexOf(toPath) == -1 && user_token) {
        //不在白名单,并且user_token存在
        next()
    }

    /**
     * 判断锁屏
     */
    if (store.getters.isLock && to.path !== '/lock') {
        next({
            path: '/lock'
        })
    }
});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • vue实现滑动解锁功能

    本文实例为大家分享了vue实现滑动解锁功能的具体代码,供大家参考,具体内容如下 话不多说,直接上代码: <template>   <div>     <div id="box">       <div class="bgColor"></div>       <div class="txt">滑动解锁</div>       <!--给i标签添加上相应字体图

  • Vue滑块解锁组件使用方法详解

    本文实例为大家分享了Vue滑块解锁组件的使用,供大家参考,具体内容如下 依据 JS拖动滑块验证 开发的 Vue 滑块解锁组件. <template>   <div ref="wrap" class="slider-unlock">     <div class="before">请按住滑块,拖动到最右边</div>     <div ref="after" class=&q

  • vue项目记录锁定和解锁功能实现

    本文实例为大家分享了vue项目记录锁定和解锁功能实现代码,供大家参考,具体内容如下 一.定义 api 模块 import request from '@/utils/request'   export default {     // 分页查询     getHospitalList(current, limit, searchObj) {         return request({             url: `/admin/hospital/findPageHospital/${

  • Vue项目中添加锁屏功能实现思路

    1. 实现思路 ( 1 ) 设置锁屏密码 ( 2 ) 密码存localStorage (本项目已经封装h5的sessionStorage和localStorage) ( 3 ) vuex设置 SET_LOCK state.isLock = true (为true是锁屏状态) ( 4 ) 在路由里面判断vuex里面的isLock(为true锁屏状态不能让用户后退url和自行修改url跳转页面否则可以) (1)设置锁屏密码 handleSetLock() { this.$refs['form'].v

  • vue滑动解锁组件使用方法详解

    本文实例为大家分享了vue滑动解锁组件的使用,供大家参考,具体内容如下 这是一个pc端的滑动解锁组件 效果图: 话不多说,直接上代码 html部分 <template>     <div class="dragVerify">         <div class="spout" ref="spout">             <div                 class="slidi

  • vue+element实现输入密码锁屏

    本文实例为大家分享了vue+element实现输入密码锁屏的具体代码,供大家参考,具体内容如下 1.页面中个的点击事件 通过vuex来存在状态 /**   * 锁屏功能   */             lock() {                 console.log('锁屏')                 const that = this                 this.$prompt('请输入锁屏密码', '提示', {                     con

  • 利用vue + element实现表格分页和前端搜索的方法

    前言 ElementUI是饿了么前端开源的一个基于Vue的前端框架,已经帮我们封装好了一系列功能性的组件,比如栅格系统.表格.表单.树形菜单.通知等.对于搞后台管理界面的项目,特别是不需要考虑兼容ie8.ie9以下的项目.ElementUI是一个不错的选择. 而且ElementUI的文档写得十分详尽,参照demo可以很快上手. 本文主要介绍了关于vue + element实现表格分页和前端搜索的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 实现思路 1.前端后台管理

  • vue+element实现表单校验功能

    要实现这个功能其实并不难,element组件直接用就可以, 但是我在使用过程中碰到了几个坑,就记录下来,分享给大家,避免落坑,话不多说,直接上过程...... 表单校验功能: 实现这个功能,总共分为以下4布: 1.在el-form标签中定义:rules="rules";ref="reference" 2.在el-form-item定义prop="name"; 3.在选项data中定义rules校验规则; 4.在提交方法中检查用户行为 templa

  • Vue+Element实现动态生成新表单并添加验证功能

    首先有一个这样的需求,表单中默认有一个联系人信息,用户可以再添加新的联系人信息 点击添加更多联系人之后 官方文档中有写用v-for来实现新增表单,但是那是单表单的新增,现在多表单的新增,可以考虑的实现方法是先写死一个必须的表单,需要新增的两个表单放在一个div里,在div中使用v-for生成,达到同时新增的效果 代码如下 //必填一个联系人的表单 <el-form-item class="rules" label="通知对象:" prop="noti

  • vue+element实现表格新增、编辑、删除功能

    几天前,需要做一个需求:新增一个xml文件时,添加数量不确定.属性相同的xml标签,想了想可以用表格做啊,属性相同,使用统一的表头,下面的属性值只是进行增删改不就行了,就类似于mysql给表里填数据一样. 可是目前似乎还没有表格的直接增删改一行的操作,那要怎么实现呢?于是,通过上网以及自己的思考,终于实现了,代码.思路以及效果图如下: 1 html部分: <el-button type="success" @click="addRow(tableData)"&

  • vue+element项目中过滤输入框特殊字符小结

    可以在main.js中写入方法 Vue.prototype.validSe = function (value, number = 255) { value = value.replace(/[`-*~!@#$%^&*()_\-+=<>?:"{}|,./;'\\[\]·~!@#¥%--&*()--\-+={}|<>?:""[].:'',..]/g, '').replace(/\s/g, ""); if (value.

  • VUE+Element环境搭建与安装的方法步骤

    1,安装node,确保安装4.0版本以上,具体的安装可以百度. 2,在命令行创建文件夹 3,安装Vue-cli 输入:cnpm install -g vue-cli , 回车, 等待安装.... 输入:vue ,查看vue相关信息 4,初始化项目 vue init webpack last_demo 然后等一下就会出现相关的信息,再自己去选择安装的一些设置 安装完的时候,你的文件夹就变成了这样了: 如果你的文件夹中没有node_modules的文件,那么你就要在命令行中打开你的项目并输入: np

  • vue中Element-ui 输入银行账号每四位加一个空格的实现代码

    一.问题描述: 我们在输入银行账号会设置每四位添加一个空格,输入金额,每三位添加一个空格.那么,在vue,element-ui 组件中,如何实现呢? 二.效果图: 三.实现代码: <el-table-column prop="account" label="银行账号"> <template slot-scope="scope"> <el-input type="text" maxlength=&q

  • 在vue+element ui框架里实现lodash的debounce防抖

    事情起因在:我使用element ui框架里的远程搜索框,在单选时,组件内部已经做了防抖,query是在一段时间内的字符串.但是在多选时,并没有做防抖,而是每输入一个字符都要向后台发一次请求,所以必须防抖,官方推荐使用lodash的debounce 在解决这个问题时,我遇到的坎儿主要有以下: 我首先在项目里用npm安装lodash,先全局安装,然后安装到项目 npm install -g lodash npm install --save lodash 安装后,我就在我要用防抖的组件里,引入lo

  • 解决vue+element 键盘回车事件导致页面刷新的问题

    背景 今天发现输入框输入内容后回车就会刷新页面 解决 <el-form :inline="true" @submit.native.prevent> </el-form> el-from 加上 @submit.native.prevent 具体是参考element-ui文档解决的 W3C 标准中有如下规定: When there is only one single-line text input field in a form, the user agent

随机推荐