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 = 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 router

App.vue

<template>
  <div id="app">
    <!-- 路由占位符 -->
    <router-view></router-view>
  </div>
</template>

<script>
export default {
    
    
  name: 'app'
}
</script>

<style>
</style>

启动

npm run serve

可以从浏览看到如下界面
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_28988969/article/details/104480996