zoukankan      html  css  js  c++  java
  • vue.js2.0+elementui ——> 后台管理系统

    前言:

    因为观察到vue.js的轻量以及实时更新数据的便捷性,于是新项目便决定使用vue.js2.0以及与之配套的elementui来完成。只是初次接触新框架,再使用过程中,遇见了各种各样“奇葩”的问题,在所有人的努力下,幸好该项目已接近尾声,就此便小谈一下自己的收获吧!

    过程:

    【使用到的文档】

    https://cn.vuejs.org/v2/guide/syntax.html(vuejs)

    http://element.eleme.io/#/zh-CN(elementui)

    http://lodashjs.com/docs/(lodash.js:主要用于处理与数组相关的问题)

    【遇见的问题集结】

    .1111

    1.select选择器赋不上值

    问题描述:点击select下拉框,能选到下拉框中的数据,但是却选不上值,即回显不上选择到的数据。

    解决方法:原来是版本问题。只需将elementui升级到1.3.0即可。(历史遗留问题吧~)

    22

    2.将后台服务器返回的数据绑定在前台页面上

    问题描述:现存在一个下拉框,但是下拉框的数据是通过后台的一个方法查询得来并返回给前台,问题就是应该怎样将数据绑定在该下拉框中呢?

    解决方法:使用mouted方法,将后台获得的数据绑定在该select的model中即可,例如

    3

    ...
    mounted() {
                this.$nextTick(() => { //更新所选组别下拉框数据
                    apiclient.usergroup_getugname().then(res =>{  //用户组别下拉框数据
                        this.filters.s_gid = res;
                    });
                });
                this.search();
            }
    ...

    其中:apiclient.usergroup_getugname()为后台获取用户组别下的所有符合条件的数据,this.filters.s_gid为该下拉框的v-model数据。

    3.select的校验不通过

    问题描述:选好下拉框,并且赋好值,但是需要进行非空校验,于是使用官网上的校验方式(如下),却总是报错:“xxx is not a string”

    ...
     rules: {
              name: [//校验input框
                { required: true, message: '请输入活动名称', trigger: 'blur' },
                { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
              ],
              region: [//校验select选择器
                { required: true, message: '请选择活动区域', trigger: 'change' }
              ],
            ...
    }
    ...

    于是,在将整个select下拉框的值写成固定的,再使用上面的校验方法的时候,居然不报错了。最终更是不知道应该从何下手解决……直到看到这个:

    33

    https://github.com/yiminghe/async-validator(适合校验的文档)

    在这里面,有着详细的介绍,还有一些我们未曾发现的“小秘密”,这样问题便迎刃而解

    ...
     rules: {
              name: [//校验input框
                { required: true, message: '请输入活动名称', trigger: 'blur' },
                { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
              ],
              region: [//校验select选择器
                { required: true,type:'number', message: '请选择活动区域', trigger: 'change' }
              ],
            ...
    }
    ...

    看文档,一定要认真点,仔细点!

    后言:

    没入手vue.js+elementui之前,总觉得这个有点难,只是因为自己不太熟悉;而当自己凭借喜欢以及工作需要慢慢了解它后,才发现原来并不难,而只是自己给它附上了一层“神秘”的面纱而已。其实在这个项目中遇见的问题还很多,后续继续总结。

  • 相关阅读:
    Python中replace 不起作用的问题
    java 获取视频时长、大小
    MySQL 自定义排序
    加 synchronized 关键字进行同步
    SQL 查询当前周的开始、结束日期
    Java 按照一定的规则生成递增的编号
    Java中BigDecimal的8种舍入模式
    Lamada 表达式之 sort 排序
    搭建Java环境
    初识JAVA(学习记录)
  • 原文地址:https://www.cnblogs.com/zhengyeye/p/6904249.html
Copyright © 2011-2022 走看看