Vue桌面端组件库:Element

官网:https://element.eleme.cn/#/zh-CN
GitHub:https://github.com/ElemeFE/element

1、什么是ElementUI?

Element 饿了么前端出品的一套 基于 Vue 2.0 的桌面端组件库,可用来构建中大型后台管理项目

1.1、搭建elementUI脚手架(vue-admin-template)

# Clone project
git clone https://github.com/PanJiaChen/vue-admin-template.git 
# Install dependencies
npm install 
# Serve with hot reload at localhost:9528
npm run dev 
# Build for production with minification
npm run build 
# Build for production and view the bundle analyzer report
npm run build --report
  • 在执行完npm run dev后发现浏览器自动打开了vue-admin-template登录页面,点击登录,此时模板页面就搭建好了。

打开文件夹vue-admin-template,主要的目录结构如下图所示:

1.2 项目初始化调整

1.2.1 关闭语法规范性检查

修改config/index.js ,将useEslint的值改为false

此配置作用: 是否开启语法检查,语法检查是通过ESLint 来实现的。

我们现在科普一下,什么是ESLint :

  • ESLint 是一个语法规则和代码风格的检查工具,可以用来保证写出语法正确、风格统一的代码。如果我们开启了Eslint , 也就意味着要接受它非常苛刻的语法检查,包括空格不能少些或多些,必须单引不能双引,语句后不可以写 分号等等,这些规则其实是可以设置的。作为初学者,最好先关闭这种校验,否则会浪费很多精力在语法的规范性上。如果以后做真正的企业级开发,建议开启。

1.2.2 国际化设置

  • 打开main.js 找到这句代码
import locale from 'element‐ui/lib/locale/lang/en'
  • 我们将en修改为zn-CN
import locale from 'element‐ui/lib/locale/lang/zh‐CN'

修改后组件都是按照中文的习惯展示

1.2.3 与easy-mock对接

(1) 修改config下的dev.env.js中的BASE_API为easy-mock的Base URL

....  
BASE_API: '"http://10.211.5.3:7300/mock/5af314a4c612420d0d7650c7"',  
....

修改后发现无法登录上vue-admin-templates,原因是修改了BASE_API,需要在自己的Easy-mock中修改验证

(2) easy-mock添加登陆认证模拟数据 地址: /user/login

提交方式:post

内容:

{  
  "code": 20000,  
  "data": {    
    "roles": ["admin"],    
    "role": ["admin"],    
    "name": "admin",    
    "avatar": "https://wpimg.wallstcn.com/f778738c‐e4f8‐4870‐b634‐56703b4acafe.gif"  
  }
}

(3) 添加返回用户信息url模拟数据 地址:/user/info

提交方式:get

内容:

{  
  "code": 20000,  
  "data": {    
    "roles": ["admin"],    
    "role": ["admin"],    
    "name": "admin",    
    "avatar": "https://wpimg.wallstcn.com/f778738c‐e4f8‐4870‐b634‐56703b4acafe.gif"  
  }
}

此时又可以登录上vue-admin-template,且成功与自己的easy-mock对接上了。

2.elementUI的table组件,实现列表展示

(1) 在src/api/下创建gathering.js,书写代码:

import request from '@/utils/request'
export default{    
  getList(){        
    return request({                
      url:'/gathering/gathering',                
      method:'get'            
    });    
  }
} 

导入request模块实际上是对ajax的封装(在utils/request.js中),上述的url和method即为请求的url和method

(2) 在views/table中创建 gathering.vue

vue主要分为视图区<template>、逻辑区/代码区<script>(用于控制视图区的显示)


<template>
  <el-table :data="list" border style="width: 100%">
    <el-table-column prop="id" label="活动ID" width="180"></el-table-column>
    <el-table-column prop="name" label="活动名称" width="180"></el-table-column>
    <el-table-column prop="sponsor" label="主办方" width="180"></el-table-column>
    <el-table-column prop="address" label="活动地址" width="180"></el-table-column>
    <el-table-column prop="starttime" label="开始日期" width="180"></el-table-column>
    <el-table-column prop="endtime" label="结束日期" width="180"></el-table-column>
  </el-table>
</template>
 
<script>
//将我们刚才书写的gathering.js导入到该vue中,并声明其作为变量gatheringApi
import gatheringApi from '@/api/gathering'
export default {
  data() {
    return {
      list: []
    }
  },
  created() {
    this.fetchData()
  },
  methods: {
    fetchData() {
      gatheringApi.getList().then(response => {
        this.list = response.data
      })
    }
  }
}
</script>

(3) 修改router/index.js中的path和import('@/views/table/gathering') 其中path为访问路径,import为views文件夹中的table文件夹中的gathering.vue文件

{    
  path: '/gathering',    
  component: Layout,    
  children: [{        
    path: 'index',        
    name: 'Form',        
    component: () => import('@/views/table/gathering'),        
    meta: { title: '活动管理', icon: 'form' }      
  }]  
}

(4) reload工程 : npm run dev

(5) plus:如果此时你在开发者工具中能正常接收数据,但是无法显示,考虑easy-mock中的接口设置,返回值是否为20000等。


{
  "code": 20000,
  "flag": true,
  "message": "@string",
  "data|10": [{
    "id": "@string",
    "name": "@cword(8,12)",
    "summary": "@cword(20,40)",
    "detail": "@cword(20,40)",
    "sponsor": "@string",
    "image": "@image",
    "starttime": "@date",
    "endtime": "@date",
    "address": "@county(true)",
    "enrolltime": "@date",
    "state": "@string",
    "city": "@string"
  }]
}

3.使用pagination实现分页

我们已经通过表格组件完成了列表的展示,接下来需要使用分页组件完成分页功能

  • 一般对于分页,都需要前端传递给后端两个参数:①当前页码 ②每页显示条数

由于笔者项目中用到了Easy Mock,所以我们第一步应该修改Easy Mock中的接口,产生更真实的模拟数据

(1)修改接口/gathering/gathering/search/{page}/{size} method:POST
(2)在gathering.js中添加新方法search,page当前页码,size每页显示条数,searchMap查询条件

参考返回数据结构:


<script>
import gatheringApi from '@/api/gathering'
export default {
  data() {
    return {
      total: 0 ,       //总记录数
      list: [],
      currentPage: 1,  //初始值为1
      pageSize: 10,     //每页显示条数
      searchMap: {}     //查询条件
    }
  },
  created() {
    this.fetchData()
  },
  methods: {
    fetchData() {
      gatheringApi.search(this.currentPage,this.pageSize,this.searchMap).then(response => {
        this.list = response.data.rows
        this.total = response.data.total
      })
    }
  }
}
</script>

此时js部分(逻辑处理层)我们已经完成,参考官方文档:完成分页组件UI层

plus:@代表调用的方法,当每页显示个数和当前页码改变时会调用方法fetchData,:name代表属性

<el-pagination      
  @size-change="fetchData"      
  @current-change="fetchData"      
  :current-page="currentPage"      
  :page-sizes="[5, 10, 20]"      
  :page-size="10"      
  layout="total, sizes, prev, pager, next, jumper"      
  :total="total">  
</el-pagination>

plus:如果加入该<el-pagination>到<template>中报错,考虑在<template>下添加一个<div>标签,因为<template>下只能有一个标签加入后即只有一个<div>标签,否则将存在<el-table>标签和<el-pagination>标签,故报错。

4. 使用分页+条件查询

需求:在分页列表的基础上实现条件查询功能【使用到了表单控件、文本输入控件、日期输入控件、行内表单等】

image

总体template代码:

<template>
  <div>
    <br/>
    <el-form :inline="true">
      <el-form-item label="活动名称">
        <el-input v-model="searchMap.name"></el-input>   
      </el-form-item>
      <el-form-item label="活动日期">
        <el-date-picker v-model="searchMap.starttime_1" type="date" placeholder="选择开始日期">
      </el-date-picker>
        <el-date-picker v-model="searchMap.starttime_2" type="date" placeholder="选择结束日期">
      </el-date-picker>
      </el-form-item>
      <el-button @click="fetchData()" type="primary">查询</el-button>
    </el-form>
    ...... 
  </div>
</template>

5-6. 弹出窗口、消息提示、select下拉框

需求:界面中加入"新增"按钮,点击弹出编辑窗口,点击“修改”按钮,关闭窗口并刷新表格,弹出提示(成功或失败)

plus:注意!需要在return内部声明一个实体对象,用于存储表单数据 ,如:renturn{ pojo:{} }

(省略了一部分代码)新增city.js,并导出(参考gathering.js)。在gathering.vue中导入city,并在打开视图时就加载城市:

created() {    
  this.fetchData()    
  cityApi.getList().then(response => {      
    this.cityList = response.data    
  })  
}

不要忘记在return中加入city这个实体对象,否则为空报错。如return{ cityList:[] }

<template>视图层代码:

<el-dialog title="编辑" :visible.sync="dialogFormVisible">
  <el-form :model="form" label-width="100px">
    <el-form-item label="活动名称" :label-width="formLabelWidth">
      <el-input v-model="pojo.name" placeholder="活动名称"></el-input>
    </el-form-item>
    <el-form-item label="基本地址" :label-width="formLabelWidth">
      <el-input v-model="pojo.address" placeholder="基本地址"></el-input>
    </el-form-item>
    <el-form-item label="开始日期" :label-width="formLabelWidth">
      <el-date-picker v-model="pojo.starttime" type="date" placeholder="选择开始日期">
      </el-date-picker>
    </el-form-item>
    <el-form-item label="截至日期" :label-width="formLabelWidth">
      <el-date-picker v-model="pojo.endtime" type="date" placeholder="选择截至日期">
      </el-date-picker>
    </el-form-item>
    <el-form-item label="报名截止" :label-width="formLabelWidth">
      <el-date-picker v-model="pojo.enrolltime" type="date" placeholder="选择截至日期">
      </el-date-picker>
    </el-form-item>
    <el-form-item label="活动详情" :label-width="formLabelWidth">
      <el-input v-model="pojo.detail" type="textarea" :rows="3" placeholder="请输入内容"></el-input>
    </el-form-item>
    <el-form-item label="选择城市">
      <el-select v-model="pojo.city" placeholder="请选择城市">
        <el-option v-for="item in cityList" :key="item.value" :label="item.name" :value="item.id">
        </el-option>
    </el-select>
    </el-form-item>
    <el-form-item label="是否可见">
       <el-switch v-model="pojo.status" active-value="1" inactive-value="0" ></el-switch>
    </el-form-item>
    <el-form-item>
       <el-button type="primary">保存</el-button>
       <el-button type="primary" @click="dialogFormVisible = false">关闭</el-button>
    </el-form-item>
  </el-form>
</el-dialog>

当我们点击保存按钮的时候,则触发几个动作:①弹出消息提示框(消息内容来自于响应体中的message) ②判断消息状态是否为true,为true则刷新列表(调用之前的刷新列表方法) ③关闭窗口(设置dialogVisible = false),主要代码如下:

<template>
...
    <el-form-item>
       <el-button type="primary" @click="handlerSave()">保存</el-button>
       <el-button type="primary" @click="dialogFormVisible = false">关闭</el-button>
    </el-form-item>
...
</template>
 
<script>
  ...
  methods:{
    handlerSave(){
      gatheringApi.save(this.pojo).then(response => {
        alert(response.message)
        if(response.flag){         //如果成功
          this.fetchData();        //刷新列表
        }
      })
      this.dialogFormVisible=false //关闭窗口
    }
  }
  ...
</script>

7、在列表显示页面右侧执行修改操作

需求:在表格的操作列增加"修改"按钮,点击修改按钮弹出窗口并显示数据,点击保存按钮保存 修改并刷新表格。

需求分析:在点击修改按钮时候,首先需要打开窗口(修改dialogVisible = true),其次获取点击的数据行id,根据该id查询数据并回显,在点击保存按钮时候,执行上面所讲的保存操作。

由于我们使用Easy-Mock模拟数据,我们首先需要修改根据id查询数据的

(1)修改easymock接口/gathering/gathering/{id} (GET)
(2)修改src/api/gathering.js,增加方法定义

findById(id) {   
  return request({      
    url: `/gathering/gathering/${id}`,      
    method: 'get'   
  })
}

(3)修改src/views/table/gathering.vue的js脚本部分,新增handleEdit()方法

handleEdit(id){   
  this.dialogFormVisible=true  //打开窗口    
  gatheringApi.findById(id).then(response=>{      
    if(response.flag){        
      this.pojo=response.data      
    }    
  })
}

(4)在表格table中增加模板列 ,模板列中防止修改按钮,调用handleEdit方法

<el-table-column label="操作" width="100">      
  <template slot-scope="scope">        
    <el-button @click="handleEdit(scope.row.id)" type="text" size="small">修改</el-button>      
  </template>
</el-table-column>

fixed="right"的作用是定义此列为右固定列slot-scope用于指定当前行的上下文。
使用scope.row可以获取行对象,此处我们需要获得当前行的id,故使用scope.row.id

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    流觞小菜鸟阅读 1,739评论 2 8
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    王喂马_阅读 6,441评论 1 77
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    小姜先森o0O阅读 9,389评论 0 72
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    35eeabfa0772阅读 3,251评论 7 12
  • Vue2.0+组件库总结 UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基...
    szch阅读 1,958评论 1 52