天天看點

Vue項目中使用Element-ui

說明:這裡我通過一個簡單的登入元件,來示範如何在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      

繼續閱讀