element ui分页器与多选框结合应用,数据保留与回显

前言

vue的UI框架非常多,我司后台主要是用饿了么团队的element ui(http://element.eleme.io/#/zh-CN)开发的,顺便吐槽下之前开发移动端用的是饿了么的mint ui,坑贼多,有空整理下。。。。

业务场景

可以简单理解为一个专场拼接的功能,可以往里面插入各种模块。左边是预览区,右边是控制区(木图帮助大家脑补下emmm),一个模块可以插入很多次,我们这里就当只插入商品模块,商品模块的控制区域(展示商品小图预览然后可以删除),点击+号弹出弹层选择商品。
算了还是上个图吧


微信截图_20180419204707.png

弹窗就不放了,element ui 带多选框分页器的demo就是
把这块拆分出来,就是预览区的此模块为父级组件(其上还有预览区为最顶级组件),控制区域为子组件,弹层为子组件调用的模块
关于数据的问题的话可以使用vuex也可以$emit往上一级一级传就不细说了。

DOM结构

<el-table ref="productTable" :data="list" @selection-change="select" @select="choserow" border show-overflow-tooltip stripe>
  <el-table-column
    label-class-name="table_header"
    label="全选"
    type="selection"
    header-align="center"
    width="100"></el-table-column>
  <el-table-column
    label-class-name="table_header"
    label="商品名称"
    prop="name"
    header-align="center"
    width="555">
    <template slot-scope="scope">
      <img class="productImg" :src="scope.row.img_cover"  alt="商品主图">
      <p class="productP">
        <a>{{ scope.row.title }}</a><br>
      </p>
    </template>  
  </el-table-column>
  <el-table-column
    label-class-name="table_header"
    label="项目类型"
    prop="product_type"
    header-align="center"
    width="150"></el-table-column>
  <el-table-column
    label-class-name="table_header"
    label="上架时间"
    prop="online_date"
    header-align="center"
    width="250"></el-table-column>
  <el-pagination class="page" ref="elPagition"
        background
        layout="prev, pager, next"
        :total="pagination.total"
        :page-size="+pagination.page_size"
        :current-page="pagination.page"
        @current-change="page"
      ></el-pagination>
</el-table>

数据

data() {
  return {
    is_visible: false, // todo: 弹层是否可以显示
    list: [], // 列表数据源
    selected: [], // 真实选中的值,用于最后返回
    pagination: {
      page: 1,
      page_size: Number,
      total: 1
    },
    menu1List: [],  //筛选相关 三级层连
    menu2List: [],
    itemList: [],
    checkList: [], // 记录之前选中的
    title: '', // 搜索后不清空双向绑定的值
    tname: '', // 同上,拿来搜索的值
    form: {
      item_id: '',
      menu1_id: '',
      menu2_id: '',
    }
  }
},

功能梳理

1、表格经过搜索、分页后,数据保留

table绑定的selection-change只能拿到当前表格选中的值,因此要设置两个数组。每次触发selection-change将当前结果放入selected,当list重新刷新之前,处理checkList

this.checkList = this.unique( this.checkList.concat( this.selected ) )

unique( arr ) {
  // 带有getset的对象似乎不能用es6数组去重
  // return Array.from(new Set(arr))
  // const res = new Map();
  // return arr.filter((a) => !res.has(a) && res.set(a, 1))
  let hash = {}
  return arr.reduce( function ( item, next ) {
    hash[next.pid] ? '' : hash[next.pid] = true && item.push( next )
    return item
  }, [] )
},

2、自动勾选

很显然我们这个需求是可以选中已有模块,此时弹窗时数据应同步到table中并选中相应元素。其次在换页、重新搜索时,也应把checkList内的值重新选中。
因为实在没找着column api里有关于默认勾选的设置,或许是我眼瞎,求指正。。。 就只能在页面组件load、list刷新时手动勾选。

//其他组件可以通过调用此ref的load()来调出
load( ...rest ) {
  ...//通过参数传好checkList后
  this.autoSelect( this.checkList )
},
autoSelect( arr ) {
  this.$nextTick( () => {
    if ( this.list !== undefined && arr !== undefined ) {
      this.list.forEach( ( v, i ) => {
        arr.forEach( ( _v, _i ) => {
          if ( v.pid === _v.pid ) {
            this.$refs.productTable.toggleRowSelection( v, true )
          }
        } )
      } )
    }
  } )
},

3、切换模块table重置

table模块只存在一个,因此每次load的时候都需要重置搜索条件、page。但是手动修改data里面的current-page对应的值是失效的。
比如走之前是2,关闭了(或者重新打开时)需要重设page,当前page是1,但是分页器组件内依旧是2,因此再切换到2分页的时候不会触发事件。
我们可以在监听弹层的is_visible

watch: {
    is_visible() {
      // 页码为其他关闭弹层后 再打开弹层应当将当前page设为1,需要同时设置分页器内的lastEmittedPage为1,否则会出点了页码没反应的bug
      !this.is_visible && ( this.$refs.elPagition.lastEmittedPage = 1 )
    }
  },

这样既可

顺便求推荐一波坑少的UI框架

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,475评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,019评论 4 62
  • 前些天华为裁员风波闹得沸沸扬扬,被裁员的均为34岁以上的老员工。想想自己也混混沌沌的到了36岁的光景,赶紧上招聘网...
    俞创木阅读 224评论 0 2
  • 随手点开简书,看看缓缓增加的篇幅量,心里甚是惭愧,大半年过去了,才写了二十几篇,速度太慢呀,我对自己说。不由自主地...
    走过不惑阅读 427评论 0 2
  • 记录三件好事 1 睡到自然醒,快11点了。起来漱口吃早餐。出到街上买了两盒月饼寄给阿艳。 一个人收到礼物总会欢喜的...
    梁超文阅读 1,911评论 0 3