当前位置:   article > 正文

Element-Ui

element-ui

安装环境搭建

Element-Ul是饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库,手机端有对应框架是Mint UI 。

中文文档:http://element-cn.eleme.io/#/zh-CN github地址:https://github.com/ElemeFE/element

1:安装node

端开发框架和环境都是需要 Node.js ,先安装node.js开发环境,vue的运行是要依赖于node的npm的管理工具来实现,下载https://nodejs.org/en/,安装完成之后,打开cmd开始输入命令。(我用的是win10系统,所以需要管理员权限,右键点击以管理员身份运行cmd),不然会出现很多报错。

2:查看node的版本号

下载好node之后,以管理员身份打开cmd管理工具,,输入 node -v ,回车,查看node版本号,出现版本号则说明安装成功。

输入命令: node -v

3:安装淘宝npm镜像

由于npm是国外的,使用起来比较慢,我们这里使用淘宝的cnpm镜像来安装vue. 淘宝的cnpm命令管理工具可以代替默认的npm管理工具。

输入命令:npm install -g cnpm --registry=https://registry.npm.taobao.org

4:安装全局vue-cli脚手架

淘宝镜像安装成功之后,我们就可以全局vue-cli脚手架,输入命令:cnpm install --global vue-cli 回车;验证是否安装成功,在命令输入vue,出来vue的信息,及说明安装成功;

输入命令:cnpm install --global vue-cli

5:开始进入主题,初始化一个vue项目

我这里是在d盘里面新建一个项目,先用d:的命令,回车键进入d盘;回车键默认创建项目信息。

vue init webpack itemname

出现这样的提示,初始化成功

运行初始化demo,输入命令npm run dev;运行一下初始后的demo,弹出访问地址,如果没有问题则进行安装elementUI;准备好好之后,开始引入饿了么elementUI组件。

6:安装 elementUI

npm i element-ui -S

快捷键ctrl+c,终止批处理操 作吗(Y/N),在输入命令npm i element-ui -S

注意:安装过程中出现这样的bug的时候,需要解决

解决办法:尝试 删除项目中的 package-lock.json 文件 和 node_modules 文件夹,然后再尝试 npm install.

成功安装组件显示如下

7:在components文件夹下面创建test.vue文件,复制一段elementUI官方文档的代码,进行测试

  1. <template>
  2. <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64" text-color="#fff" active-text-color="#ffd04b">
  3. <el-menu-item index="1">处理中心</el-menu-item>
  4. <el-submenu index="2">
  5. <template slot="title">我的工作台</template>
  6. <el-menu-item index="2-1">选项1</el-menu-item>
  7. <el-menu-item index="2-2">选项2</el-menu-item>
  8. <el-menu-item index="2-3">选项3</el-menu-item>
  9. </el-submenu>
  10. <el-menu-item index="3">
  11. <a href="https://www.ele.me" target="_blank">订单管理</a>
  12. </el-menu-item>
  13. </el-menu>
  14. </template>
  15. <script>
  16. export default {
  17. data() {
  18. return {
  19. activeIndex: '1',
  20. activeIndex2: '1'
  21. };
  22. },
  23. methods: {
  24. handleSelect(key, keyPath) {
  25. console.log(key, keyPath);
  26. }
  27. }
  28. }
  29. </script>

8:在App.vue中引入test.vue

  1. <template>
  2. <div id="app">
  3. <img src="./assets/logo.png">
  4. <router-view/>
  5. <Test></Test>
  6. </div>
  7. </template>
  8. <script>
  9. import Test from './components/test.vue'
  10. export default {
  11. components:{
  12. Test,
  13. },
  14. name: 'App'
  15. }
  16. </script>
  17. <style>
  18. #app {
  19. font-family: 'Avenir', Helvetica, Arial, sans-serif;
  20. -webkit-font-smoothing: antialiased;
  21. -moz-osx-font-smoothing: grayscale;
  22. text-align: center;
  23. color: #2c3e50;
  24. margin-top: 60px;
  25. }
  26. </style>

9:打开main.js,加入element-ui的js和css

import ElementUI from 'element-ui' //element-ui的全部组件
import 'element-ui/lib/theme-chalk/index.css'//element-ui的css
Vue.use(ElementUI) //使用elementUI

10:再次运行,组件中的效果如下:

输入命令:

npm run dev

时间选择器

打开test.vue文件,开始写代码

  1. <template>
  2. <div>
  3. <el-time-picker
  4. is-range
  5. v-model="value"
  6. range-separator="-"
  7. start-placeholder="开始时间"
  8. end-placeholder="结束时间"
  9. placeholder="选择时间范围">
  10. </el-time-picker>
  11. </div>
  12. </template>
  13. <script>
  14. export default {
  15. data() {
  16. return {
  17. value: [new Date(2016, 9, 10, 8, 40), new Date(2016, 9, 10, 9, 40)],
  18. };
  19. }
  20. }
  21. </script>

npm run dev 运行,浏览器显示如下,实现了一个简单的时间选择器

出现和隐藏动画

点击按钮的时候,元素会呈现一个出现和隐藏的动画功能。

  1. <template>
  2. <div>
  3. <el-button @click="show = !show">点击按钮</el-button>
  4. <div style="display: flex; margin-top: 20px; height: 100px;">
  5. <transition name="el-fade-in-linear">
  6. <div v-show="show" class="transition-box">我会消失在人海之中</div>
  7. </transition>
  8. </div>
  9. </div>
  10. </template>
  11. <script>
  12. export default {
  13. data: () => ({
  14. show: true
  15. })
  16. }
  17. </script>
  18. <style>
  19. .transition-box {
  20. margin-bottom: 10px;
  21. width: 300px;
  22. height: 100px;
  23. border-radius: 4px;
  24. background-color: #42B983;
  25. text-align: center;
  26. color: #fff;
  27. padding: 40px 20px;
  28. box-sizing: border-box;
  29. margin-left: 520px;
  30. }
  31. </style>

左侧导航栏

在用Element UI框架的时候

  1. <template>
  2. <div>
  3. <el-row class="tac">
  4. <el-col :span="4">
  5. <el-menu
  6. default-active="2"
  7. class="el-menu-vertical-demo"
  8. @open="handleOpen"
  9. @close="handleClose"
  10. background-color="#545c64"
  11. text-color="#fff"
  12. active-text-color="#ffd04b">
  13. <el-submenu index="1">
  14. <template slot="title">
  15. <i class="el-icon-s-platform"></i>
  16. <span>服务大厅</span>
  17. </template>
  18. <el-menu-item-group>
  19. <el-menu-item index="1-1">在场服务</el-menu-item>
  20. <el-menu-item index="1-2">历史服务</el-menu-item>
  21. </el-menu-item-group>
  22. </el-submenu>
  23. <el-submenu index="2">
  24. <template slot="title">
  25. <i class="el-icon-s-tools"></i>
  26. <span>系统设置</span>
  27. </template>
  28. <el-menu-item-group>
  29. <el-menu-item index="1-1">权限管理</el-menu-item>
  30. <el-menu-item index="1-2">角色管理</el-menu-item>
  31. </el-menu-item-group>
  32. </el-submenu>
  33. <el-submenu index="3">
  34. <template slot="title">
  35. <i class="el-icon-user-solid"></i>
  36. <span>人员数据</span>
  37. </template>
  38. <el-menu-item-group>
  39. <el-menu-item index="1-1">人员数量</el-menu-item>
  40. <el-menu-item index="1-2">人员位置</el-menu-item>
  41. </el-menu-item-group>
  42. </el-submenu>
  43. <el-submenu index="4">
  44. <template slot="title">
  45. <i class="el-icon-message-solid"></i>
  46. <span>健康报警</span>
  47. </template>
  48. <el-menu-item-group>
  49. <el-menu-item index="1-1">心率报警</el-menu-item>
  50. <el-menu-item index="1-2">血压报警</el-menu-item>
  51. </el-menu-item-group>
  52. </el-submenu>
  53. </el-menu>
  54. </el-col>
  55. </el-row>
  56. </div>
  57. </template>
  58. <script>
  59. export default {
  60. methods: {
  61. handleOpen(key, keyPath) {
  62. console.log(key, keyPath);
  63. },
  64. handleClose(key, keyPath) {
  65. console.log(key, keyPath);
  66. }
  67. }
  68. }
  69. </script>

导航菜单效果如下所示

## 导航栏跳转路由

### 1:components 新建页面

### 2:打开app.vue写代码

  1. <template>
  2. <div>
  3. <el-col :span="2">
  4. <el-menu
  5. :default-active="this.$route.path"
  6. router mode="horizontal"
  7. class="el-menu-vertical-demo"
  8. @open="handleOpen"
  9. @close="handleClose"
  10. background-color="#545c64"
  11. text-color="#fff"
  12. active-text-color="#ffd04b">
  13. <el-menu-item v-for="(item,i) in navList" :key="i" :index="item.name">
  14. <template slot="title">
  15. <i class="el-icon-s-platform"></i>
  16. <span> {{ item.navItem }}</span>
  17. </template>
  18. </el-menu-item>
  19. </el-menu>
  20. </el-col>
  21. <router-view class="menu-right"/>
  22. </div>
  23. </template>
  24. <script>
  25. export default {
  26. data() {
  27. return {
  28. navList:[
  29. {name:'/components/ServiceHall',navItem:'服务大厅'},
  30. {name:'/components/Management',navItem:'权限管理'},
  31. {name:'/components/User',navItem:'用户管理'},
  32. {name:'/components/Personnel',navItem:'人员数据'},
  33. {name:'/components/Alarm',navItem:'报警中心'},
  34. ] }
  35. },
  36. methods: {
  37. handleOpen(key, keyPath) {
  38. console.log(key, keyPath);
  39. },
  40. handleClose(key, keyPath) {
  41. console.log(key, keyPath);
  42. }
  43. }
  44. }
  45. </script>
  46. <style>
  47. .menu-right{
  48. margin-left:200px;
  49. }
  50. </style>

3:路由index.js

  1. import Vue from 'vue'
  2. import Router from 'vue-router'
  3. import HelloWorld from '@/components/HelloWorld'
  4. import ServiceHall from '@/components/ServiceHall'
  5. import Management from '@/components/Management'
  6. import User from '@/components/User'
  7. import Personnel from '@/components/Personnel'
  8. import Alarm from '@/components/Alarm'
  9. Vue.use(Router)
  10. export default new Router({
  11. routes: [
  12. {
  13. path: '/',
  14. name: 'HelloWorld',
  15. component: HelloWorld
  16. },
  17. {
  18. path: '/components/ServiceHall',
  19. name: 'ServiceHall',
  20. component: ServiceHall
  21. }, {
  22. path: '/components/Management',
  23. name: 'Management',
  24. component: Management
  25. },
  26. {
  27. path: '/components/User',
  28. name: 'User',
  29. component: User
  30. },{
  31. path: '/components/Personnel',
  32. name: 'Personnel',
  33. component: Personnel
  34. },{
  35. path: '/components/Alarm',
  36. name: 'Alarm',
  37. component: Alarm
  38. }
  39. ]
  40. })

4:新页面的内容

  1. <template>
  2. <div>
  3. 我是权限管理页面
  4. </div>
  5. </template>
  6. <script>
  7. </script>
  8. <style>
  9. </style>

5:效果就可以看了

axios请求数据

1:进入项目,npm安装

   npm install axios --save

2.在main.js下引用axios

  import axios from 'axios'

3:准备json数据

自己写了一个json数据,放在服务器上,现在要通过vue项目调用数据 http://www.intmote.com/test.json

4:跨域问题,设置代理,利用proxyTable属性实现跨域请求

在config/index.js 里面找到proxyTable :{} ,然后在里面加入以下代码

   proxyTable: {
  '/api': {
    target: 'http://www.intmote.com',//设置你调用的接口域名和端口号 别忘了加http
    changeOrigin: true,//允许跨域
    pathRewrite: {
      '^/api': '' //这个是定义要访问的路径,名字随便写 
    }
  }
},

5:打开一个界面User.vue,开始写请求数据的方法

 methods: {
            getData() {
                axios.get('/api/test.json').then(response => {
                    console.log(response.data);
                }, response => {
                    console.log("error");
                });
            }
        }

User.vue参考代码:

  1. <template>
  2. <div id="app">
  3. </div>
  4. </template>
  5. <script>
  6. import axios from "axios";
  7. export default {
  8. name: "app",
  9. data() {
  10. return {
  11. itemList: []
  12. }
  13. },
  14. mounted() {
  15. this.getData();
  16. },
  17. methods: {
  18. getData() {
  19. axios.get('/api/test.json').then(response => {
  20. console.log(response.data);
  21. }, response => {
  22. console.log("error");
  23. });
  24. }
  25. }
  26. }
  27. </script>

6:再次运行npm run dev

这个时候,我们可以看见,请求的数据

Mock的使用

1:在项目里面新建一个mock文件夹,在mock文件夹里面新建一个test.json文件

test.json:

  1. {
  2. "first":[
  3. {"name":"520","nick":"我爱你"},
  4. {"name":"521","nick":"我愿意"},
  5. {"name":"1314","nick":"一生一世"}
  6. ]
  7. }

2:在build目录下找到webpack.

  1. // mock code
  2. const express = require('express')
  3. const app = express()
  4. const posts = require('../mock/test.json')
  5. const routes = express.Router()
  6. app.use('/api', routes)
  7. // 如果是post请求,那么将get改为post即可
  8. devServer: {
  9. ...
  10. before(app){
  11. app.get('/api/test', (req, res) => {
  12. res.json(posts)
  13. })
  14. }
  15. }

 

dev.conf.js文件,编写以下代码

3:浏览器输入http://localhost:8080/api/test

成功看到模拟数据

4:使用第三方http请求库axios进行ajax请求

  1. methods: {
  2. getData() {
  3. axios.get('http://localhost:8080/api/test').then(response => {
  4. console.log(response.data);
  5. }, response => {
  6. console.log("error");
  7. });
  8. }
  9. }

vue页面代码参考

  1. <template>
  2. <div id="app">
  3. </div>
  4. </template>
  5. <script>
  6. import axios from "axios";
  7. export default {
  8. name: "app",
  9. data() {
  10. return {
  11. itemList: []
  12. }
  13. },
  14. mounted() {
  15. this.getData();
  16. },
  17. methods: {
  18. getData() {
  19. axios.get('http://localhost:8080/api/test').then(response => {
  20. console.log(response.data);
  21. }, response => {
  22. console.log("error");
  23. });
  24. }
  25. }
  26. }
  27. </script>

5:在浏览器里面,我们可以看到,mock里面的数据请求成功显示如下

页面渲染

其实步骤很简单,代码如下

  1. <template>
  2. <div id="app">
  3. <div v-for="item in itemList">
  4. <span>{{item.name}}</span>
  5. <span>{{item.nick}}</span>
  6. </div>
  7. </div>
  8. </template>
  9. <script>
  10. import axios from "axios";
  11. export default {
  12. name: "app",
  13. data() {
  14. return {
  15. itemList: []
  16. }
  17. },
  18. mounted() {
  19. this.getData();
  20. },
  21. methods: {
  22. getData() {
  23. axios.get('http://localhost:8080/api/test').then(response => {
  24. console.log(response.data);
  25. this.itemList =response.data.first;
  26. }, response => {
  27. console.log("error");
  28. });
  29. }
  30. }
  31. }
  32. </script>

打开界面,既可以看到,所需要的数据一家展示在前端的界面了

axios表格分页

接着之前的项目继续写,打开一个vue界面,在里面写如下代码:

  1. <template>
  2. <div>
  3. <el-table :data="tableData.slice((currentPage-1)*pagesize,currentPage*pagesize)" style="width: 100%">
  4. <el-table-column prop="id" label="日期" width="180">
  5. </el-table-column>
  6. <el-table-column prop="name" label="姓名" width="180">
  7. </el-table-column>
  8. <el-table-column prop="price" label="地址">
  9. </el-table-column>
  10. </el-table>
  11. <div class="pagination">
  12. <el-pagination
  13. @size-change="handleSizeChange"
  14. @current-change="handleCurrentChange"
  15. :current-page="currentPage"
  16. :page-sizes="[5, 10, 20, 40]"
  17. :page-size="pagesize"
  18. layout="total, sizes,prev, pager, next"
  19. :total="tableData.length"
  20. prev-text="上一页"
  21. next-text="下一页">
  22. </el-pagination>
  23. </div>
  24. </div>
  25. </template>
  26. <script>
  27. import axios from "axios";
  28. export default {
  29. name: "app",
  30. data() {
  31. return {
  32. currentPage: 1, //默认显示页面为1
  33. pagesize: 5, // 每页的数据条数
  34. tableData: [], //需要data定义一些,tableData定义一个空数组,请求的数据都是存放这里面
  35. }
  36. },
  37. mounted() {
  38. this.getData();
  39. },
  40. methods: {
  41. getData() {
  42. axios.get('http://localhost:8080/api/test').then(response => {
  43. console.log(response.data);
  44. this.tableData = response.data;
  45. }, response => {
  46. console.log("error");
  47. });
  48. },
  49. //每页下拉显示数据
  50. handleSizeChange: function(size) {
  51. this.pagesize = size;
  52. /*console.log(this.pagesize) */
  53. },
  54. //点击第几页
  55. handleCurrentChange: function(currentPage) {
  56. this.currentPage = currentPage;
  57. /*console.log(this.currentPage) */
  58. },
  59. }
  60. }
  61. </script>

test.json

  1. [
  2. {
  3. "id": 0,
  4. "name": "Item 0",
  5. "price": "徐家汇"
  6. },
  7. {
  8. "id": 1,
  9. "name": "Item 1",
  10. "price": "$1"
  11. },
  12. {
  13. "id": 2,
  14. "name": "Item 2",
  15. "price": "$2"
  16. },
  17. {
  18. "id": 3,
  19. "name": "Item 3",
  20. "price": "徐家汇"
  21. },
  22. {
  23. "id": 4,
  24. "name": "Item 4",
  25. "price": "徐家汇"
  26. },
  27. {
  28. "id": 5,
  29. "name": "Item 5",
  30. "price": "$5"
  31. },
  32. {
  33. "id": 6,
  34. "name": "Item 6",
  35. "price": "$6"
  36. },
  37. {
  38. "id": 7,
  39. "name": "Item 7",
  40. "price": "$7"
  41. },
  42. {
  43. "id": 8,
  44. "name": "Item 8",
  45. "price": "徐家汇"
  46. },
  47. {
  48. "id": 9,
  49. "name": "Item 9",
  50. "price": "$9"
  51. },
  52. {
  53. "id": 10,
  54. "name": "Item 10",
  55. "price": "$10"
  56. },
  57. {
  58. "id": 11,
  59. "name": "Item 11",
  60. "price": "$11"
  61. },
  62. {
  63. "id": 12,
  64. "name": "Item 12",
  65. "price": "徐家汇"
  66. },
  67. {
  68. "id": 13,
  69. "name": "Item 13",
  70. "price": "$13"
  71. },
  72. {
  73. "id": 14,
  74. "name": "Item 14",
  75. "price": "$14"
  76. },
  77. {
  78. "id": 15,
  79. "name": "Item 15",
  80. "price": "$15"
  81. },
  82. {
  83. "id": 16,
  84. "name": "Item 16",
  85. "price": "徐家汇"
  86. },
  87. {
  88. "id": 17,
  89. "name": "Item 17",
  90. "price": "$17"
  91. },
  92. {
  93. "id": 18,
  94. "name": "Item 18",
  95. "price": "$18"
  96. },
  97. {
  98. "id": 19,
  99. "name": "Item 19",
  100. "price": "徐家汇"
  101. },
  102. {
  103. "id": 20,
  104. "name": "Item 20",
  105. "price": "$20"
  106. }
  107. ]

效果如下 

到这里就成功的实现了一个表格和分页了,数据是用mock模拟的,实际中换成后端的接口就可以了 。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/511948
推荐阅读
相关标签
  

闽ICP备14008679号