說明:這裡我通過一個簡單的登入元件,來示範如何在vue項目中使用Element-ui
按需導入element-ui元件
打開src目錄,找到plugins目錄下的element.js檔案,導入需要的元件
import Vue from 'vue'
// 按需導入element-ui元件
import { Button, Form, FormItem, Input, Row, Col, Message } from 'element-ui'
// 按鈕
Vue.use(Button)
// 表單
Vue.use(Form)ppe
Vue.use(FormItem)
// 輸入框
Vue.use(Input)
// 布局
Vue.use(Row)
Vue.use(Col)
// 消息提示挂載到vue
Vue.prototype.$message =
在元件中使用element-ui
在src目錄下的,components目錄下,建立一個Login.vue檔案
具體的element-ui文檔,這裡不在詳細介紹,需要的話請到element-ui官網查詢
<template>
<div class="login_container">
<div class="login_box">
<!-- label-width 表單域标簽的寬度 -->
<!-- model 表單綁定的data -->
<!-- rules 表單校驗規則 -->
<!-- ref 表單的引用 -->
<el-form
class="loginForm"
label-width="0px"
:model="loginForm"
:rules="loginFormRules"
ref="loginFormRef"
>
<div class="loginTitle">
<h1>資料系統平台</h1>
</div>
<el-form-item prop="account">
<el-input prefix-icon="fas fa-user" v-model="loginForm.account" placeholder="請輸入賬号"></el-input>
</el-form-item>
<el-form-item prop="password">
<el-input
prefix-icon="fas fa-lock"
v-model="loginForm.password"
placeholder="請輸入密碼"
show-password
></el-input>
</el-form-item>
<el-form-item>
<el-row>
<el-col :span="12" class="btns">
<el-button type="primary" @click="userLogin">登入</el-button>
</el-col>
<el-col :span="12" class="btns">
<el-button type="info" @click="resetLoginForm">重置</el-button>
</el-col>
</el-row>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script>
export default {
data() {
return {
// 登入表單資料
loginForm: {
account: '',
password: ''
},
// 表單校驗規則,trigger指定什麼時候觸發校驗
loginFormRules: {
account: [
{ required: true, message: '請輸入賬号', trigger: 'blur' },
{
min: 4,
max: 20,
message: '賬号長度在 4 到 20 個字元',
trigger: 'blur'
}
],
password: [
{ required: true, message: '請輸入密碼', trigger: 'blur' },
{
min: 6,
max: 15,
message: '密碼長度在 6 到 15 個字元',
trigger: 'blur'
}
]
}
}
},
methods: {
// 使用者登入
userLogin() {
// 登入前校驗
this.$refs.loginFormRef.validate(valid => {
if (!valid) return
// todo 校驗通過
this.$message.success('執行登入操作')
})
},
// 重置登入表單,這裡的loginFormRef是上面指定的,其他的是固定寫法
resetLoginForm() {
this.$refs.loginFormRef.resetFields()
}
}
}
</script>
<style lang="less" scoped>
// 登入容器
.login_container {
background-color: #2b4b6b;
height: 100%;
}
// 登入盒子
.login_box {
width: 450px;
height: 276px;
background-color: #fff;
border-radius: 5px;
position: relative;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
//登入表單
.loginForm {
position: absolute;
bottom: 0;
width: 100%;
padding: 0 20px;
box-sizing: border-box;
}
// 按鈕區域
.btns {
display: flex;
justify-content: center;
}
// 登入表單标題
.loginTitle {
text-align: center;
}
</style>
設定路由
打開src目錄,找到router目錄下的index.js檔案
import Vue from 'vue'
import VueRouter from 'vue-router'
// 導入登入元件
import Login from '../components/Login.vue'
Vue.use(VueRouter)
const routes = [
// 根路徑重定向到登入
{
path: '/',
redirect: '/login'
},
// 登入
{
path: '/login',
component: Login
}
]
const router = new VueRouter({
routes
})
export default
App.vue
<template>
<div id="app">
<!-- 路由占位符 -->
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'app'
}
</script>
<style>
</style>
啟動
npm run serve