本文详细介绍了ElementUI实战,包括其安装、基本组件的使用和布局设计等内容,帮助开发者快速掌握ElementUI的使用方法。文章还涵盖了表格、表单和路由导航等高级功能的实现,提供了丰富的示例代码供读者参考。
Vue.js基础Vue.js 是一个渐进式框架,它可以帮助开发者高效地构建用户界面。Vue.js 的核心库只关注视图层,它提供了简洁、直观的 API,使得开发者能够迅速上手。以下是一个简单的 Vue.js 示例:
<!DOCTYPE html>
<html>
<head>
<title>Vue.js 示例</title>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
</head>
<body>
<div id="app">
{{ message }}
</div>
<script>
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
</script>
</body>
</html>
``
## ElementUI简介
ElementUI 是一套基于 Vue 2.x 的桌面端组件库,它提供了丰富的 UI 组件来帮助开发者快速构建高效的单页应用。ElementUI 的设计遵循阿里巴巴的《规范》,并结合了原生 HTML、CSS 和 JavaScript 的最佳实践,使得开发出的应用界面更加美观、规范,同时也能提高开发效率。
## 安装ElementUI
要使用 ElementUI,首先需要安装 Vue.js。安装完成后,通过 npm 安装 ElementUI。在命令行中输入以下命令:
```bash
npm install vue
npm install element-ui
引入ElementUI样式和脚本
安装完成后,需要在项目中引入 ElementUI 的样式和脚本。以下是一个简单的引入示例:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-button type="primary">主要按钮</el-button>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>
``
## 布局组件
ElementUI 提供了多种布局组件,包括 Row 和 Col 组件,以及 Flex 布局。
### Row和Col布局
Row 和 Col 组件用于创建行布局。以下是一个简单的 Row 和 Col 的例子:
```html
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-row>
<el-col :span="12">左侧内容</el-col>
<el-col :span="12">右侧内容</el-col>
</el-row>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>
Flex布局
Flex 布局可以通过设置 type
属性来实现。以下是一个 Flex 布局的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-row type="flex" justify="space-around">
<el-col :span="6">内容一</el-col>
<el-col :span="6">内容二</el-col>
</el-row>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>
常见布局案例分析
假设我们需要创建一个双栏布局,左侧宽度为 30%,右侧宽度为 70%。可以通过调整 :span
属性来实现:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-row>
<el-col :span="7">
<div class="grid-content bg-purple">左侧内容</div>
</el-col>
<el-col :span="17">
<div class="grid-content bg-purple-light">右侧内容</div>
</el-col>
</el-row>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>
常用组件使用
ElementUI 提供了丰富的组件,这里介绍几个常用的组件:Button 按钮组件、Input 输入框组件和 Select 选择器组件。
Button按钮组件
Button 组件用于创建按钮。ElementUI 提供了多种按钮样式和属性。以下是一个简单的 Button 组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-button type="primary">主要按钮</el-button>
<el-button type="success">成功按钮</el-button>
<el-button type="warning">警告按钮</el-button>
<el-button type="danger">危险按钮</el-button>
<el-button type="info">信息按钮</el-button>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>
Input输入框组件
Input 组件用于创建文本输入框。以下是一个简单的 Input 组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-input placeholder="请输入内容" v-model="input" clearable></el-input>
<span>{{ input }}</span>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
input: ''
}
})
</script>
</body>
</html>
Select选择器组件
Select 组件用于创建下拉选择器。以下是一个简单的 Select 组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-select v-model="select" placeholder="请选择">
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value">
</el-option>
</el-select>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
select: '',
options: [
{ value: '选项1', label: '选项1' },
{ value: '选项2', label: '选项2' },
{ value: '选项3', label: '选项3' },
{ value: '选项4', label: '选项4' }
]
}
})
</script>
</body>
</html>
表格和表单
ElementUI 提供了 Table 表格组件和 Form 表单组件,帮助开发者高效地完成数据展示和表单提交。
Table表格组件
Table 组件用于创建表格。以下是一个简单的 Table 组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-table :data="tableData" style="width: 100%">
<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>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
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>
</body>
</html>
Form表单组件
Form 组件用于创建表单。以下是一个简单的 Form 组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<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="区域一"></el-option>
<el-option label="区域二" value="区域二"></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>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
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>
</body>
</html>
表单验证
上述例子中的表单字段进行了验证。rules
对象定义了表单字段的验证规则,通过表单验证后才能提交表单。validate
方法用于验证表单字段,如果验证通过则调用回调函数,并在回调函数中处理验证结果。
表格和表单的综合运用
以下是一个综合了表格和表单的示例:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-form :model="form" :rules="rules" ref="form" label-width="100px" class="demo-ruleForm">
<el-form-item label="活动名称" prop="name">
<el-input v-model="form.name"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('form')">提交</el-button>
</el-form-item>
</el-form>
<el-table :data="tableData" style="width: 100%">
<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>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
form: {
name: ''
},
rules: {
name: [
{ required: true, message: '请输入活动名称', trigger: 'blur' },
{ min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
]
},
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 弄' }
]
},
methods: {
submitForm(formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
alert('提交成功!');
} else {
console.log('表单验证失败!');
return false;
}
});
}
}
})
</script>
</body>
</html>
路由与导航
ElementUI 可以与 Vue Router 结合使用,实现页面的跳转和导航。以下是如何使用 Vue Router 进行导航的例子。
Vue Router简介
Vue Router 是 Vue.js 官方的路由插件,它提供了丰富的功能,包括路由配置、组件懒加载等。以下是一个简单的 Vue Router 配置:
import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)
export default new Router({
routes: [
{
path: '/',
name: 'home',
component: () => import('@/components/Home.vue')
},
{
path: '/about',
name: 'about',
component: () => import('@/components/About.vue')
}
]
})
使用ElementUI进行路由导航
在 ElementUI 中,我们可以使用 router-link
组件来创建导航链接。以下是一个简单的路由导航例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-menu :router="true">
<el-menu-item index="/">
<i class="el-icon-menu"></i>
<span slot="title">首页</span>
</el-menu-item>
<el-menu-item index="/about">
<i class="el-icon-document"></i>
<span slot="title">关于</span>
</el-menu-item>
</el-menu>
<router-view></router-view>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/vue-router/dist/vue-router.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
Vue.use(Router)
var router = new Router({
routes: [
{
path: '/',
name: 'home',
component: () => import('@/components/Home.vue')
},
{
path: '/about',
name: 'about',
component: () => import('@/components/About.vue')
}
]
})
var app = new Vue({
el: '#app',
router: router
})
</script>
</body>
</html>
导航菜单组件
ElementUI 提供了多种导航菜单组件,如 el-menu
和 el-submenu
。以下是一个使用 el-menu
组件的例子:
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<el-menu :router="true" default-active="2">
<el-menu-item index="/home" @click="handleClick('home')">首页</el-menu-item>
<el-submenu index="/about">
<template slot="title">关于</template>
<el-menu-item-group>
<template slot="title">关于我们</template>
<el-menu-item index="/about">关于我们</el-menu-item>
<el-menu-item index="/history">发展历程</el-menu-item>
</el-menu-item-group>
<el-menu-item-group title="联系我们">
<el-menu-item index="/contact">联系方式</el-menu-item>
</el-menu-item-group>
</el-submenu>
</el-menu>
</div>
<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/vue-router/dist/vue-router.js"></script>
<script class="lazyload" src="" data-original="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
Vue.use(Router)
var router = new Router({
routes: [
{
path: '/home',
name: 'home',
component: () => import('@/components/Home.vue')
},
{
path: '/about',
name: 'about',
component: () => import('@/components/About.vue')
},
{
path: '/history',
name: 'history',
component: () => import('@/components/History.vue')
},
{
path: '/contact',
name: 'contact',
component: () => import('@/components/Contact.vue')
}
]
})
var app = new Vue({
el: '#app',
router: router,
methods: {
handleClick(name) {
router.push({ name: name })
}
}
})
</script>
</body>
</html>
共同学习,写下你的评论
评论加载中...
作者其他优质文章