VUE腳手架框架編寫簡(jiǎn)潔的登錄界面的實(shí)現(xiàn)
前言
一個(gè)好的前端開發(fā)項(xiàng)目,都是一個(gè)團(tuán)隊(duì)負(fù)責(zé)一個(gè)部分進(jìn)行通力合作的。簡(jiǎn)單的一個(gè)系統(tǒng)網(wǎng)站一般包含登錄、主體、各個(gè)模塊功能這三個(gè)大部分,現(xiàn)在我們寫的登錄界面,我們一般編寫這樣的登錄界面可以說有一定的固定套路。
安裝Vue腳手架
1、我們一Windows 10為例子,安裝Vue 3腳手架前,我們先要配置node js環(huán)境;
2、接下來,安裝Vue,安裝的過程不多說,大家可以到官網(wǎng)去自行下載就可以了,鏈接Vue.js;Vue.js - The Progressive JavaScript
或者,可以選擇另一種安裝方式:
打開控制臺(tái),輸入一下命令行
npm install vue -g
3、等待安裝Vue,還需安裝Vue-cli (腳手架),輸入如下命令進(jìn)行安裝
npm install -g vue-cli
4、對(duì)項(xiàng)目文件進(jìn)行初始化 還可以使用webpack作為腳手架,命令如下:
vue init webpack qiubite-project
創(chuàng)建登錄界面的文件--login.Vue
安裝完畢后,這里本人使用的是vscode軟件,創(chuàng)建一個(gè)登錄模塊的目錄頁,

配置路由-- router.js
接下來,我們要把vue的router路由配置給配置好,如下:
import Vue from 'vue'
import VueRouter from 'vue-router'
import Login from '../components/Login.vue'
import Home from '../components/Home.vue'
Vue.use(VueRouter)
const router = new VueRouter({
routes: [
{ path: '/', redirect: '/login' },
{ path: '/login', component: Login },
{
path: '/home',
component: Home,
redirect: '/equipment', // 重定向功能,只要訪問home地址,就會(huì)重定向到wequipment地址
children: [
{ path: '/equipment', component: Equip },
{ path: '/deploy', component: Deploy },
{ path: '/history', component: History },
{ path: '/analysis', component: Analysis },
{ path: '/power', component: Power },
{ path: '/remote', component: Remote }]// welcome為home的子屬性
}
],
mode: 'history'
})
router.beforeEach((to, from, next) => {
if (to.path === '/login') return next()
const tokenStr = window.sessionStorage.getItem('token')
if (!tokenStr) return next('/login')
next()
})
export default router這里我們掛載一個(gè)路由守衛(wèi),router.beforeEach,這里面to將要訪問的路徑,from 代表從哪一個(gè)路徑跳到哪一個(gè)去beforeEach,next 是一個(gè)函數(shù),表示放行,next()放行 next('/login)強(qiáng)制跳轉(zhuǎn)。用戶如果訪問login,可以直接跳轉(zhuǎn),獲取token。
配置main.js
import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
// 導(dǎo)入全局樣式表
import './assets/css/global.css'
import axios from 'axios'
axios.defaults.baseURL = 'http://39.101.161.112:9000'
axios.interceptors.request.use(config => {
console.log(config)
config.headers.Authorization = window.sessionStorage.getItem('token')
// 通過axios攔截器添加token驗(yàn)證
return config
// 最后必須要return出去
})
Vue.prototype.$http = axios
Vue.config.productionTip = false
Vue.use(ElementUI)
Vue.use(AMap)
Vue.use(VideoPlayer)
new Vue({
router,
store,
render: h => h(App)
}).$mount('#app')
編寫登錄界面--Login.Vue
<template>
<div class="login_container">
<!-- 登錄模塊盒子 -->
<div class="login-box">
<!-- 圖片盒子 -->
<div class="avatar_box">
<img src="../assets/wo.jpg" alt="">
<h3 class="text">丘 比 特</h3>
</div>
<!-- 登陸表單區(qū)域 -->
<el-form label-width="0px" class="login_form" :model="loginForm" :rules="loginFormRules" ref="loginFormRef">
<!-- :model數(shù)據(jù)綁定對(duì)象,綁定到login from這個(gè)表單中,rules表單的驗(yàn)證規(guī)則對(duì)象 -->
<!-- 用戶登錄 -->
<el-form-item prop="username">
<el-input prefix-icon="el-icon-user-solid" v-model="loginForm.username" size="mini" ></el-input>
<!-- v-model雙向綁定,綁定到用戶名 -->
</el-form-item>
<!-- 密碼 -->
<el-form-item prop="password">
<el-input prefix-icon="el-icon-lock" v-model="loginForm.password" type="password" size="mini" ></el-input>
<!-- v-model雙向綁定,綁定到用戶登錄密碼,type="password可以使得密碼隱藏"-->
</el-form-item>
<!-- 按鈕區(qū)域 -->
<el-form-item class="btns">
<el-button type="primary" @click="login" size="mini" >登錄</el-button>
<!-- 為登錄綁定一個(gè)單擊事件,名為login -->
<el-button type="info" @click="resetLoginForm" size="mini">取消</el-button>
<!-- click綁定單擊事件,名為resetloginfrom -->
</el-form-item>
</el-form>
</div>
</div>
</template>
<script>
import {Login} from '../network/login'
export default {
data () {
return {
loginForm: {
username: '',
password: ''
},
loginFormRules: {
username: [
{ required: true, message: '請(qǐng)輸入登錄名稱', trigger: 'blur' },
{ min: 3, max: 10, message: '長(zhǎng)度在 3 到 10 個(gè)字符', trigger: 'blur' }
],
password: [
{ required: true, message: '請(qǐng)輸入登錄密碼', trigger: 'blur' },
{ min: 3, max: 15, message: '長(zhǎng)度在 3 到 15 個(gè)字符', trigger: 'blur' }
]
}
}
},
methods: {
resetLoginForm () {
this.$refs.loginFormRef.resetFields()
},
login () {
this.$refs.loginFormRef.validate( valid => {
if (!valid) {return this.$message.error('用戶名密碼不正確')}
Login(this.loginForm).then( res => {
console.log(res);
if (res.code !== 0)
{return this.$message.error('登錄失敗')}
this.$message.success('登陸成功')
window.sessionStorage.setItem('token', res.token)
this.$router.push('/home')
}).catch( error => {
console.log(error);
})
})
}
}
}
</script>
<style lang="less" scoped>
.login_container {
background-color: #0e1729;
background-image: url(../assets/pic2.png);
height: 100%;
}
.login-box {
width: 360px;
height: 240px;
background-color: #fff;
border-radius: 3px;
position: absolute;
left: 50%; //距離左側(cè)50%
top: 50%; // 距離頂部505
transform: translate(-50%, -50%); //橫軸上移動(dòng)50%,縱移動(dòng)50%
}
.avatar_box {
height: 100px;
width: 100px;
border: 1px solid #eee;
border-radius: 50%;
padding: 10px;
box-shadow: 0 0 10px #eee;
position: absolute;
left: 50%;
top:-40%;
transform: translate(-50%);
background-color: rgb(32, 181, 201);
img {
width: 100%;
height: 100%;
border-radius: 50%;
background-color: #eee;
}
}
.login_form {
position: absolute;
bottom: 0;
width: 100%;
padding: 0 20px;
box-sizing: border-box;
}
.btns {
display: flex;
justify-content: flex-end;
}
.text {
text-align: center;
margin-top: 10px;
font-size: 20px;
font-family: 宋體;
}
</style>1、 validate回調(diào)函數(shù),完成登錄表單前的預(yù)校驗(yàn);
2、將登陸成功以后的token,保存到客戶端的sessionstorage中;
3、項(xiàng)目中除了登陸之外的其他api接口,必須將token保存到客戶端;
4、 this.$router.push('/home)是通過編程式導(dǎo)航跳轉(zhuǎn)到后臺(tái),路由地址為/home。
結(jié)果展示

總結(jié)
用戶登錄首先完成賬號(hào)密碼輸入,當(dāng)用戶進(jìn)行賬戶密碼登錄操作,系統(tǒng)將驗(yàn)對(duì)賬戶密碼進(jìn)行查詢、登錄表單數(shù)據(jù)綁定驗(yàn)證。當(dāng)用戶登錄成功時(shí),用戶信息將會(huì)被記錄到session中,用戶信息將會(huì)被記錄到系統(tǒng)日志中,再通過重定向即可跳轉(zhuǎn)到系統(tǒng)首頁。當(dāng)用戶登錄失敗時(shí),系統(tǒng)彈出“登陸失敗,請(qǐng)重新登錄”提示信息。當(dāng)用戶登錄賬戶密碼不合法時(shí),系統(tǒng)將彈出“登錄信息不合法”提示信息,用戶需進(jìn)行賬戶密碼重置重新登陸。如下是用戶登錄界面的時(shí)序圖:

到此這篇關(guān)于VUE腳手架框架編寫簡(jiǎn)潔的登錄界面的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)VUE 登錄界面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中使用jquery滑動(dòng)到頁面底部的實(shí)現(xiàn)方式
這篇文章主要介紹了vue中使用jquery滑動(dòng)到頁面底部的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
vue 基于element-ui 分頁組件封裝的實(shí)例代碼
這篇文章主要介紹了vue 基于element-ui 分頁組件封裝的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12
Vue3?<script?setup?lang=“ts“>?的基本使用
<script setup>?是在單文件組件 (SFC) 中使用?composition api?的編譯時(shí)語法糖,本文主要講解<script setup>?與?TypeScript?的基本使用,感興趣的朋友跟隨小編一起看看吧2022-12-12

