精华内容
参与话题
问答
  • ElementUI快速入门

    万次阅读 多人点赞 2019-01-04 09:30:54
    本文主要从几个方面快速入门ElementUI 1、什么是ElementUI ? 掌握elementUI脚手架搭建 2、掌握elementUI的table组件的使用,实现列表功能 3、掌握elementUI的pagination组件的使用,实现分页功能 ...

    本文主要从几个方面快速入门ElementUI

    1、什么是ElementUI ? 掌握elementUI脚手架搭建

    2、掌握elementUI的table组件的使用,实现列表功能

    3、掌握elementUI的pagination组件的使用,实现分页功能

    4、掌握elementUI的form相关组件的使用,实现条件查询功能

    5、掌握elementUI的dialog组件和$message的使用,实现弹出窗口和消息提示功能

    6、掌握elementUI的select组件的使用,实现下拉列表功能实现新增数据和修改数据的功能

    7、掌握confirm的使用,实现询问框,实现删除功能

     

    1、什么是ElementUI?

    Element 饿了么前端出品的一套 基于 Vue 2.0 的桌面端组件库

    官网: http://element.eleme.io/#/zh-CN

     

    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层:

    http://element-cn.eleme.io/#/zh-CN/component/pagination

    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. 使用分页+条件查询

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

    总体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下拉框

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

    涉及知识点:dialog组件、$message、switch开关、textarea文本域、form表单、select下拉框等

    参考官方文档:http://element-cn.eleme.io/#/zh-CN/component/dialog      (如何调出窗口并关闭窗口)

    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

     

    展开全文
  • elementUi——适合于Vue的UI框架

    万次阅读 多人点赞 2018-06-21 09:17:15
    简介element-ui是一个ui库,它不依赖于vue。但是却是当前和vue配合做项目开发的一个比较好的ui框架。Layout布局(el-row、el-col)element-ui借用了bootstrap框架的思想,使用了栅格布局。它把单一的分栏分为24列。...

    简介

    element-ui是一个ui库,它不依赖于vue。但是却是当前和vue配合做项目开发的一个比较好的ui框架。

    Layout布局(el-row、el-col)

    element-ui借用了bootstrap框架的思想,使用了栅格布局。它把单一的分栏分为24列。基本的使用方式如下

    <el-row>
            <el-col :span="6"><div class="grid-content bg-purple"></div></el-col>
            <el-col :span="6"><div class="grid-content bg-purple"></div></el-col>
            <el-col :span="6"><div class="grid-content bg-purple"></div></el-col>
            <el-col :span="6"><div class="grid-content bg-purple"></div></el-col>
          </el-row>

    span属性:表示col所要占领的栅格占比个数。 
    offset属性:表示col相对偏移的个数。

    Container布局容器

    这些布局容器,一般充当div来使用。

    el-container:外层容器。当子元素中包含 el-header 或 el-footer 时,全部子元素会垂直上下排列,否则会水平左右排列。

    el-header:顶栏容器

    el-footer:底部栏容器

    el-aside:侧边栏容器

    el-main:页面主视图

    icons的使用

    在element-ui 中,图标是用class就可以搞定的。

    比如一个编辑的图标就可以如下表示:

    <i class="el-icon-edit"></i>

    按钮(el-button)

    按钮是el-button来表示的

    按钮是分类的,每一种类型就对应不同的button。

    按钮的类型type可取值:’primary’、’success’、’warning’、’info’、’danger’

    plain:决定了按钮是否使用素色系列。

    round:决定了按钮是不是圆角展示。

    <div class="flex-box">
          <h2>各种button</h2>
          <el-row class="flex1 margin-left10">
            <el-col :span="3"><el-button>默认按钮</el-button></el-col>
            <el-col :span="3"><el-button type="primary">主要按钮</el-button></el-col>
            <el-col :span="3"><el-button type="success">成功按钮</el-button></el-col>
            <el-col :span="3"><el-button type="warning">警告按钮</el-button></el-col>
            <el-col :span="3"><el-button plain>默认按钮</el-button></el-col>
            <el-col :span="3"><el-button round>默认按钮</el-button></el-col>
          </el-row>
        </div>

    级联选择(el-cascader)

    这里写图片描述

    //组件
    <el-cascader
     :options="options"
      v-model="selectedOptions"
      @change="handleChange">
    </el-cascader>
    //data数据
    options: [{
      value:'1',
      label:'components',
      children: [{
        label:'input'
      },{
        label:'swiper'
      }]
    },{
      value:'1',
      label:'views'
    },{
      value:'1',
      label:'actions'
    }]

    TimePicker 时间选择器

    picker-options是一个对象。

    这个对象的属性有start、step、end、selectableRange等。

    当设置selectableRange属性时,它提供了一个时间选择的点。

    <el-time-select
      v-model="value1"
      :picker-options="{
          start:'08:30',
          step:'00:15',
          end:'18:30'
      }"
      placeholder="选择时间"
    ></el-time-select>

    日期选择器

    日期选择器的type属性,决定选择的类型,这个type可以是date、week、month、year。

    <el-date-picker
      v-model="valueDate"
      type="date"
      placeholder="选择日期">
    </el-date-picker>

    <el-date-picker
        type='week'
        v-model='value'
        placeholder='选择周'
    >
    </el-date-picker>

    DateTimePicker 日期时间选择器

    本质就是把type改为datetime。

    <el-date-picker
     v-model="value1"
      type="datetime"
      placeholder="选择日期时间">
    </el-date-picker>
    • form表单

    element-ui的form表单组件:el-form

    element-ui的formItem组件:el-form-item

    一个简单的form表单的实现如下:

    <el-form :model=''>
        <el-form-item label='用户名'>
            <el-input></el-input>
        </el-form-item>
        <el-form-item label='密码'>
            <el-input></el-input>
        </el-form-item>
    </el-form>

    form表单还有验证:form的rules就是用来验证使用。

    Table 表格

    el-table:element-ui的表格。

    el-table-column:element-ui的表格所对应的列。

    table属性中:stripe属性可以创建带斑马纹的表格。

    table属性中:border属性可以创建带斑马纹的表格。

    table属性中:height属性可实现固定表头的表格。

    <el-table
       :data="tableData"
       style="width: 100%"
       height="200"
     >
       <el-table-column fixed width="120" label="日期" prop="date"></el-table-column>
       <el-table-column width="120" label="姓名" prop="name"></el-table-column>
       <el-table-column width="360" label="地址" prop="address"></el-table-column>
     </el-table>

    Carousel 走马灯

    其实就相当于一个轮播

    type属性:可以让轮播卡片化

    interval属性:定义轮播切换的周期

    <el-carousel height="150px">
     <el-carousel-item v-for="item in 4" :key="item">
        <h3>{{ item }}</h3>
      </el-carousel-item>
    </el-carousel>

    Collapse 折叠面板

    折叠面板的el-collapse-item需要title属性。

    <el-collapse-item title="一致性 Consistency" name="1">
      <div>与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念;</div>
      <div>在界面中一致:所有的元素和结构需保持一致,比如:设计样式、图标和文本、元素的位置等。</div>
    </el-collapse-item>

    Navigation 导航

    el-menu

    el-menu:表示导航菜单的盒子。 
    el-submenu:表示导航菜单的子盒子选项。 
    el-menu-item:表示导航菜单的每一项。

    其中submenu和munuitem都是用于属性index。

    <el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect">
      <el-menu-item index="1">处理中心</el-menu-item>
      <el-submenu index="2">
        <template slot="title">我的工作台</template>
        <el-menu-item index="2-1">选项1</el-menu-item>
        <el-menu-item index="2-2">选项2</el-menu-item>
        <el-menu-item index="2-3">选项3</el-menu-item>
      </el-submenu>
      <el-menu-item index="3">订单管理</el-menu-item>
    </el-menu>

    el-tabs

    <el-tabs v-model="activeName">
        <el-tab-pane label="用户管理" name="first">
            用户管理
        </el-tab-pane>
    </el-tabs>

    Tree 树形控件

    data属性:代表着树形组件的渲染。

    <el-tree :data="data" :props="defaultProps" @node-click="handleNodeClick"></el-tree>

    来源: https://blog.csdn.net/mapbar_front/article/details/79102167

    展开全文
  • vue和element-ui使用

    万次阅读 多人点赞 2018-07-06 14:32:06
    这一篇主要是创建一个vue项目并结合饿了么框架element-ui。1.先创建vue项目,我准备把项目放在e盘下:E:\Work\RegisterProject;命令行进入这个目录:创建一个基于 webpack 模板的新项目(1)vue init webpack ...
    展开全文
  • Element-UI使用指南

    万次阅读 多人点赞 2016-11-03 17:48:53
    Element-UI使用指南 Element-UI是饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架,手机端有对应框架是 Mint UI 。 开发环境1.安装webpacknpm install -g webpack2.安装vue-clivue-cli是什么?vue-cli 是...

    Element-UI饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架,手机端有对应框架是 Mint UI

    开发环境


    1.安装webpack

    npm install -g webpack

    2.安装vue-cli

    vue-cli是什么?

    vue-cli 是vue.js的脚手架,用于自动生成vue.js模板工程的。

    使用步骤:

    • 安装vue-cli:

      npm install -g vue-cli
    • 使用vue-cli构建项目

      vue init webpack project-name  //创建一个基于webpack模板的名为project-name的项目

      目前可用的模板包括:

      • browserify–全功能的Browserify + vueify,包括热加载,静态检测,单元测试。
      • browserify-simple–一个简易的Browserify + vueify,以便于快速开始。
      • webpack–全功能的Webpack + vueify,包括热加载,静态检测,单元测试。
      • webpack-simple–一个简易的Webpack + vueify,以便于快速开始。
    • 安装项目依赖

      cd project-name    //进入项目目录
      npm install        //安装项目依赖
      npm run dev        //运行项目

    此时在浏览器打开:localhost:8080即可看到欢迎页。

    关于webpack和vue-cli的更多使用方法参见官方文档。

    • 但是这个只能在本地跑,要如何在我们自己的服务器上访问呢?此时需要执行

      npm run build

    搭建开发环境

    本来想用vue-cli重新创建项目,试了几次总是出现各种问题,没办法成功。最后在仔细查看 Element-UI官方文档快速上手 部分的时候发现 饿了么 团队给了一个他们自己的 项目模板 。于是我就用这个模板来尝试了下,结果成功了。所以,如果你不想太折腾的话,建议还是使用官方给的项目模板,可以省很多事。

    第一步:安装项目模板

    • 克隆/下载项目模板

    • 将下载的模板放到你项目的根目录下

    • 安装依赖

      npm install
    • 运行项目模板

      npm run dev

      此时在浏览器打开:localhost:8080即可看到欢迎页。

      欢迎页

    项目模板里已经把需要配置的文件都配置好了。

    第二步:安装element-ui

    第一步,我们成功安装了项目模板,接下来,我们需要安装element-ui到项目下。

    npm i element-ui@next -D

    开始使用

    接下来我们就可以参照 Element-UI官方文档上手开发了。

    例子

    我们参照官方的按钮组件使用说明,在项目模板的基础上做一个按钮的例子。其它文件不需要改动,只修改App.vue文件的内容。代码如下:

    App.vue

    <template>
      <div id="app">
        <img src="./assets/logo.png">
        <h1>{{ msg }}</h1>
        <el-button @click.native="startHacking">Let's do it</el-button>
        <div class="block">
        <span class="demonstration">显示默认颜色</span>
        <span class="wrapper">
        <el-button type="success">成功按钮</el-button>
        <el-button type="warning">警告按钮</el-button>
        <el-button type="danger">危险按钮</el-button>
        <el-button type="info">信息按钮</el-button>
        </span>
        </div>
        <br/>
        <div class="block">
          <span class="demonstration">hover 显示颜色</span>
        <span class="wrapper">
        <el-button :plain="true" type="success">成功按钮</el-button>
        <el-button :plain="true" type="warning">警告按钮</el-button>
        <el-button :plain="true" type="danger">危险按钮</el-button>
        <el-button :plain="true" type="info">信息按钮</el-button>
        </span>
        </div>
      </div>
    </template>
    <script>
    export default {
      data () {
        return {
          msg: 'Use Vue 2.0 Today!'
        }
      },
    
      methods: {
        startHacking () {
          this.$notify({
            title: 'It Works',
            message: 'We have laid the groundwork for you. Now it\'s your time to build something epic!',
            duration: 6000
          })
        }
      }
    }
    </script>
    
    <style>
    body {
      font-family: Helvetica, sans-serif;
    }
    </style>
    

    效果如下图所示:

    demo


    使用过程中碰到的问题:

    1. phantomjs安装失败

    由于源的问题,安装phantomjs必须要“搭梯子”,使用内网无法下载。所以解决的方法有两种:

    • 方法一:通过科学上网,然后安装。

    • 方法二:对于不知道怎么“搭梯子”的同学,可以通过更改源来下载,操作方法如下:

      npm install phantomjs --phantomjs_cdnurl=http://cnpmjs.org/downloads

    2.打开页面乱码

    通过 Element-UI 官方提供的项目模板开发,会发现在浏览器打开页面的时候,中文是乱码的。如下图所示:

    中文乱码

    html页面中已经设置了<meta chartset='utf-8'>

    仔细查看该页面所涉及的文件的编码格式的时候,发现引用的App.vue 文件的编码格式是GBK ,所以把该文件编码格式改为UTF-8 即可。

    展开全文
  • Element-Ui组件(二)Icon 图标

    万次阅读 多人点赞 2019-06-03 16:16:39
    Element-Ui组件(二)图标应用 本文参考Element官方文档: http://element-cn.eleme.io/#/zh-CN/component 基本用法 Element内置丰富的图标库,主要有以下2种用法: 设置类名el-icon-xxx,通常使用i元素 在...
  • element-ui中el-container容器与div布局区分

    万次阅读 热门讨论 2019-04-09 18:03:29
    用于布局的容器组件,方便快速搭建页面的基本结构: el-container:外层容器。当子元素中包含 或 时,全部子元素会垂直上下排列,...以上组件采用了 flex 布局,elemen-ui官方文档链接: http://element-cn.elem...
  • Element-Ui组件(一)页面布局

    万次阅读 2019-05-30 17:00:33
    Element-Ui组件(一)页面布局 本文参考Element官方文档: http://element-cn.eleme.io/#/zh-CN/component 常用布局 el-row与el-col可搭配实现24格栅格布局,若布局较复杂,可以嵌套使用。 el-container作为布局...
  • Element-UI安装和项目开发

    万次阅读 2018-08-21 09:12:07
    方法一:引入CDN 使用起来最简单的方法,直接引入CDN就可以...https://unpkg.com/element-ui/lib/theme-default/index.css"&gt; &lt;!-- 先引入 Vue --&gt; &lt;script src="https://u...
  • vue+element-ui的主题颜色切换

    万次阅读 2018-10-27 16:38:46
    参考了 https://mp.csdn.net/mdeditor# 的...1.安装vue-cli npm install -g vue-cli vue init webpack vue_demo cd vue_demo npm install npm run dev 2.安装element-ui及sass npm i element-ui -S npm in...
  • elementUi

    2018-06-17 17:13:53
    elementUi vue ui 前端
  • element-ui入门

    万次阅读 2019-03-08 09:39:47
    element-ui是一个ui库,它不依赖于vue。但是却是当前和vue配合做项目开发的一个比较好的ui框架。 其设计原则为: 一致性 Consistency 与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念...
  • element-ui使用总结

    千次阅读 2018-10-18 12:45:43
    1.input输入框 自定义图标 前部效果图: &amp;amp;amp;amp;amp;amp;lt;el-input type=&amp;amp;amp;amp;amp;quot;text&amp;amp;amp;amp;amp;quot; v-model=&amp;amp;amp;amp;...
  • Vue +Element UI 图片上传控件使用

    万次阅读 多人点赞 2018-07-11 16:34:12
    上一篇 Vue +Element UI +vue-quill-editor 富文本编辑器及插入图片自定义主要是写了富文本编辑器的自定义及编辑器中图片的上传并插入到编辑内容,这篇文章单独介绍一下element UI 图片上传控件的使用。首先要安装...
  • vue+element UI实现树形表格,带树形选择的复选框

    万次阅读 多人点赞 2018-09-03 09:37:00
    一:在component文件夹下新建如下treeTable文件夹,里面有2个文件: eval.js:将数据转换成树形数据 /** * @Author: jianglei * @Date: 2017-10-12 12:06:49 ...export default function treeToArray(...
  • Element UI 官网地址

    万次阅读 2018-09-30 10:16:39
    Element UI 官网地址
  • Element UI的表格table列的宽度自适应设置

    万次阅读 热门讨论 2018-03-23 16:05:22
    不要设置 width="110px" <el-table-column prop="login_id" align="center" label="工号"> </el-table-column> ...el-table-column prop="login_id" width="110px" align="center" label="工号...
  • Vue Element UI + OSS上传文件

    万次阅读 热门讨论 2018-08-06 23:08:04
      Element UI提供了upload上传组件,可以到官网查看upload组件的详细介绍;查看upload组件的上传源码upload/ajax,使用的XHR对象上传文件,在项目实践中,发现该上传方法上传大文件时会出现问题,所以决定使用阿里...
  • 手把手教你用element ui搭建后台基础框架 element ui和iview都是vue常用的框架,今天用了一下element ui搭建了一个基础版的后台框架,这里就和大家分享下,首先看一下效果图: 实现步骤: 1、项目使用vue-cli...
  • Element UI框架项目结构解析

    千次阅读 2018-12-21 21:07:25
    前言 ...这篇文章就是详细分析下Element UI项目组成以及相关的打包步骤等,旨在加深对工程化构建相关的知识点了解。 Element UI项目结构 |-- Element ​ |-- .babelrc // babel配置文件 ​ |-- ...
  • element ui 兼容低版本浏览器

    千次阅读 2019-09-03 16:27:02
    基于ES6的用Vue框架element ui写的页面,如果当需要解决兼容低版本浏览器时,会遇到在低版本浏览器中不显示效果,页面一片空白,但控制台也不报错,而在高版本可以正常显示的情况。 低版本效果: 高版本效果: ...

空空如也

1 2 3 4 5 ... 20
收藏数 113,714
精华内容 45,485
关键字:

elementui