手记

ElementUI入门指南:轻松上手组件库

概述

ElementUI 是一套基于 Vue 2.x 的桌面端组件库,由饿了么前端团队开发,提供了丰富的组件库和强大的生态支持,让前端开发者可以更快速、更高效地构建高质量的桌面端应用程序。ElementUI 不仅具有美观的设计和易用性,还支持国际化和主题定制等功能,大大提升了项目的开发效率和用户体验。

ElementUI简介

ElementUI是什么

Element UI 是一套基于 Vue 2.x 的桌面端组件库。它由饿了么前端团队开发,遵循 Vue.js 官方组件规范,具有丰富的组件库和强大的生态支持。Element UI 的出现,让前端开发者可以更快速、更高效地构建高质量的桌面端应用程序。它不仅提供了多种常用的UI组件,如按钮、表格、对话框等,还支持国际化、主题定制等功能,极大提升了项目的开发效率和用户体验。

ElementUI的特点和优势

Element UI 的主要特点和优势如下:

  1. 丰富的组件库:Element UI 提供了超过50个高质量的UI组件,覆盖了大部分常见的前端开发需求。
  2. 易用性:组件的使用方式符合 Web 标准和语义化,使得开发者可以快速上手并实现复杂的交互功能。
  3. 美观的设计:采用了 Material Design 设计语言,组件在视觉上保持一致性和美观性。
  4. 强大的生态支持:与 Vue.js 生态系统深度集成,支持 Vue CLI 3.x、Vue Router、Vuex 等,便于项目集成和维护。
  5. 国际化支持:内置了多种语言的本地化支持,满足不同国家和地区用户的需求。
  6. 灵活的主题定制:提供了简单的主题定制方案,开发者可以方便地调整样式,以满足项目需求。
  7. 社区活跃:活跃的社区支持和丰富的开源资源,使得问题解决变得容易。

ElementUI适用场景

Element UI 适用于以下几个场景:

  • 桌面端应用开发:Element UI 是为桌面端设计的,适用于需要用户界面的 web 应用程序。
  • B/S 系统:适用于企业级后台管理系统,如CRM、ERP等。
  • 中后台项目:适用于需要复杂交互和用户界面的项目。
  • 前端快速开发:Element UI 的组件库可以大大加快前端开发的速度。
  • 国际化应用:支持国际化和多语言切换,适用于全球化的项目。
  • 自定义主题:提供主题定制功能,可以满足项目在视觉设计上的需求。
ElementUI环境搭建

安装ElementUI

要开始使用Element UI,首先需要安装它。这里我们将使用npm来安装Element UI。

npm install element-ui --save

创建Vue项目

使用Vue CLI创建一个新的Vue项目。Vue CLI是官方推荐的项目脚手架工具,可以简化项目的创建和配置过程。

vue create my-elementui-app
cd my-elementui-app

引入ElementUI

接下来,在项目中引入Element UI。在 main.js 文件中,首先需要引入Element UI模块和样式。

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';

Vue.use(ElementUI);

这样就完成了Element UI的基本配置,现在可以在项目中使用Element UI提供的各种组件了。

基础组件使用

按钮和图标

Element UI提供了多种类型的按钮,包括默认按钮、主要按钮、成功按钮、危险按钮等。

<template>
  <div>
    <el-button>默认按钮</el-button>
    <el-button type="primary">主要按钮</el-button>
    <el-button type="success">成功按钮</el-button>
    <el-button type="info">信息按钮</el-button>
    <el-button type="warning">警告按钮</el-button>
    <el-button type="danger">危险按钮</el-button>
  </div>
</template>

除了按钮,Element UI还提供了丰富的图标,可以通过<i>标签和class属性来使用。

<template>
  <div>
    <i class="el-icon-edit"></i>
    <i class="el-icon-share"></i>
    <i class="el-icon-delete"></i>
  </div>
</template>

表格

表格组件是最常用的组件之一,用于展示和编辑数据。以下是一个简单的表格示例:

<template>
  <div>
    <el-table :data="tableData" >
      <el-table-column prop="date" label="日期" width="180"></el-table-column>
      <el-table-column prop="name" label="姓名" width="180"></el-table-column>
      <el-table-column prop="address" label="地址"></el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        {
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1517 弄'
        },
        {
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1519 弄'
        },
        {
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1516 弄'
        }
      ]
    };
  }
};
</script>

对话框

对话框组件用于在界面上显示模态对话框,用户可以进行确认、取消等操作。以下是一个简单的对话框示例:

<template>
  <div>
    <el-button type="text" @click="dialogFormVisible = true">打开对话框</el-button>
    <el-dialog title="提示" :visible.sync="dialogFormVisible">
      <el-form :model="form">
        <el-form-item label="活动名称" :label-width="formLabelWidth">
          <el-input v-model="form.name" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="活动区域" :label-width="formLabelWidth">
          <el-select v-model="form.region" placeholder="请选择活动区域">
            <el-option label="区域一" value="shanghai"></el-option>
            <el-option label="区域二" value="beijing"></el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click="dialogFormVisible = false">取 消</el-button>
        <el-button type="primary" @click="dialogFormVisible = false">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
export default {
  data() {
    return {
      dialogFormVisible: false,
      form: {
        name: '',
        region: '',
        date1: '',
        date2: '',
        delivery: false,
        type: [],
        resource: '',
        desc: ''
      },
      formLabelWidth: '120px'
    };
  }
};
</script>
表单组件实战

表单布局

表单布局组件提供了多种表单布局模式,例如水平布局和垂直布局。

<template>
  <div>
    <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
      <el-form-item label="活动名称" prop="name">
        <el-input v-model="ruleForm.name"></el-input>
      </el-form-item>
      <el-form-item label="活动区域" prop="region">
        <el-select v-model="ruleForm.region" placeholder="请选择活动区域">
          <el-option label="区域一" value="shanghai"></el-option>
          <el-option label="区域二" value="beijing"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
        <el-button @click="resetForm('ruleForm')">重置</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      ruleForm: {
        name: '',
        region: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入活动名称', trigger: 'blur' },
          { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
        ],
        region: [
          { required: true, message: '请选择活动区域', trigger: 'change' }
        ]
      }
    };
  },
  methods: {
    submitForm(formName) {
      this.$refs[formName].validate((valid) => {
        if (valid) {
          alert('提交成功!');
        } else {
          console.log('提交失败!');
          return false;
        }
      });
    },
    resetForm(formName) {
      this.$refs[formName].resetFields();
    }
  }
};
</script>

输入框和选择器

输入框和选择器是表单中最常用的组件。以下是一个输入框和选择器的示例:

<template>
  <div>
    <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
      <el-form-item label="活动名称" prop="name">
        <el-input v-model="ruleForm.name" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="活动区域" prop="region">
        <el-select v-model="ruleForm.region" placeholder="请选择活动区域">
          <el-option label="区域一" value="shanghai"></el-option>
          <el-option label="区域二" value="beijing"></el-option>
        </el-select>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      ruleForm: {
        name: '',
        region: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入活动名称', trigger: 'blur' },
          { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
        ],
        region: [
          { required: true, message: '请选择活动区域', trigger: 'change' }
        ]
      }
    };
  }
};
</script>
``

### 表单验证

表单验证是确保用户输入正确的关键功能。以下是一个简单的表单验证示例:

```html
<template>
  <div>
    <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
      <el-form-item label="活动名称" prop="name">
        <el-input v-model="ruleForm.name" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="活动区域" prop="region">
        <el-select v-model="ruleForm.region" placeholder="请选择活动区域">
          <el-option label="区域一" value="shanghai"></el-option>
          <el-option label="区域二" value="beijing"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
        <el-button @click="resetForm('ruleForm')">重置</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      ruleForm: {
        name: '',
        region: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入活动名称', trigger: 'blur' },
          { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
        ],
        region: [
          { required: true, message: '请选择活动区域', trigger: 'change' }
        ]
      }
    };
  },
  methods: {
    submitForm(formName) {
      this.$refs[formName].validate((valid) => {
        if (valid) {
          alert('提交成功!');
        } else {
          console.log('提交失败!');
          return false;
        }
      });
    },
    resetForm(formName) {
      this.$refs[formName].resetFields();
    }
  }
};
</script>
配置与主题定制

主题定制

Element UI 支持通过 LESS 变量来定制主题。首先需要安装 node-sassless

npm install node-sass less less-loader --save-dev

然后,在项目根目录下创建一个 theme 文件夹,并在该文件夹内创建一个 variables.less 文件。编写自定义样式变量。

// theme/variables.less
@primary-color: #1c8de3;

接下来,在 main.js 中引入自定义样式文件。

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import '@/theme/variables.less';

Vue.use(ElementUI);

语言国际化

Element UI 支持国际化,可以轻松地添加不同语言的支持。首先需要安装 vue-i18n

npm install vue-i18n --save

然后,在项目中创建 i18n 文件夹,并在该文件夹内创建一个 index.js 文件。在该文件中定义国际化的配置。

// src/i18n/index.js
import Vue from 'vue';
import VueI18n from 'vue-i18n';

Vue.use(VueI18n);

const messages = {
  en: {
    message: {
      hello: 'Hello, world!'
    }
  },
  zh: {
    message: {
      hello: '你好,世界!'
    }
  }
};

export default new VueI18n({
  locale: 'zh', // 设置默认语言
  messages
});
``

在 `main.js` 中引入国际化的配置。

```javascript
import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import '@/theme/variables.less';
import i18n from '@/i18n';

Vue.use(ElementUI);
Vue.use(i18n);

全局配置

Element UI 提供了全局配置选项,可以用来定制整个项目的样式和行为。以下是一个简单的全局配置示例:

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import '@/theme/variables.less';
import i18n from '@/i18n';

Vue.use(ElementUI, {
  i18n: (key, value) => i18n.t(key, value),
  size: 'medium' // 设置默认尺寸
});
常见问题解答

常见错误及解决方案

错误一:Element UI 组件未正确加载

解决方案:确保正确引入了 Element UI 模块和样式。

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';

Vue.use(ElementUI);

错误二:Element UI 组件样式不一致

解决方案:检查是否正确引入了样式文件,并且没有覆盖样式。

import 'element-ui/lib/theme-chalk/index.css';

错误三:Element UI 组件功能未生效

解决方案:检查是否正确使用了组件,并且传递了必要的参数。

<el-button type="primary">点击</el-button>

ElementUI更新日志查看

Element UI 的更新日志可以在其官方 GitHub 仓库的 Releases 页面查看。通过查看更新日志,可以了解每个版本的新增功能、修复的问题等。

社区支持与资源推荐

Element UI 有一个活跃的社区支持。开发者可以通过以下途径获取帮助:

  • GitHub Issues:在 GitHub 仓库中提交问题,与其他开发者交流。
  • Stack Overflow:在 Stack Overflow 上搜索 Element UI 问题,或者提问。
  • 慕课网:慕课网提供了丰富的 Element UI 教程和实战项目,适合不同层次的开发者。

此外,开发者还可以参考 Element UI 的官方文档和示例代码,来快速上手和使用。

0人推荐
随时随地看视频
慕课网APP