iview的table组件中加入超链接组件,可编辑组件,选择组件,日期组件



这篇文章主要介绍了iview的table组件中使用选择框,日期,可编辑表格,超链接等组件。

1.select选择组件

// tableColumn数组响应对象需要传入一个固定的option数组,如果该数组是异步动态生成的该组件不能正常渲染,因为在获取option数组之前table渲染时option是undefined。
supportSelect(item) {
     item.render = (h, params)=>{
         return h('Select', {
             props: {
                 value: params.row[params.column.key],
                 size: 'small',
                 transfer: true
             },
             on: {
                 'on-change': (val)=>{
                     this.insideTableData[params.index][params.column.key] = val
                 }
             },
         },item.option.map(item=>{
             return h('Option', {
                 props: {
                     value: item.value || item,
                     label: item.label || item
                 }
             }, item.label || item)
         }))
     }
     return item
 }

2.可编辑表格

// 可编辑表格使用了contenteditable属性,使得表格编辑更加简单干净
supportEdit(item, index){
    item.render = (h, params)=>{
        return h('div', {
            style: {
                padding: '4px 0',
                width: '100%'
            },
            props: {
                value: this.insideTableData[params.index][params.column.key]
            },
            attrs: {
                contenteditable: this.editable,
                title: '点击可编辑'
            },
            on: {
                'blur': evt=>{
                    evt.target.value = evt.target.innerText || params.row[params.column.key]
                    params.row[params.column.key] = evt.target.innerText
                    this.insideTableData[params.index][params.column.key] = evt.target.innerText
                }
            }
        }, params.row[params.column.key])
    }
    return item
}

3.日期组件

// 使用iview的DatePicker组件渲染就行
supportDate(item){
    item.render = (h, params)=>{
        return h('DatePicker', {
            props: {
                clearable: false,
                placeholder: '请选择日期',
                value: params.row[params.column.key],
                type: 'date',
                format: 'yyyy-MM-dd',
                size: 'small'
            },
            on: {
                'on-change': (val)=>{
                    this.insideTableData[params.index][params.column.key] = val
                }
            }
        })
    }
    return item
}

4.表格中添加超链接

// 这里的handleLink方法是在table组件中定义好的使用$emit让父组件调用
supportLink(item){
    item.render = (h, params)=>{
        return h('a', {
            style: {
                textDecoration: 'underline'
            },
            on: {
                'click': ()=>{
                    this.handleLink(params.row)
                }
            }
        }, params.row[params.column.key])
    }
    return item
}

原文地址:https://www.cnblogs.com/codebook/p/11605224.html

时间: 2024-08-28 02:59:15

iview的table组件中加入超链接组件,可编辑组件,选择组件,日期组件的相关文章

vue组件中的样式属性:scoped,解决在父组件中无法修改子组件样式问题

Scoped CSS规范是Web组件产生不污染其他组件,也不被其他组件污染的CSS规范. vue组件中的style标签标有scoped属性时表明style里的css样式只适用于当前组件元素,它是通过使用PostCSS来改变以下内容实现的: <style scoped> .example { color: red; } </style> <template> <div class="example">hi</div> </

vue组件中使用iframe元素

需要在本页面中展示vue组件中的超链接,地址栏不改变的方法: <template> <div class="accept-container"> <div class="go-back" v-show="goBackState" @click="goBack">GoBack</div> <ul> <li v-for="item in webAddres

Angular2 ng-content 在组件中嵌入内容

ng-content指令可以在组件中嵌入模板代码,方便定制可复用的组件.比如:页面的header是个通用组件,导航菜单样式已经设定好,只需在header标签内加上菜单内容.源码以前文为基础. 父组件使用方法: <app-header #header [title]="title" name="{{name}}" (checkEmitter)="onCheckedChange($event)" > <menu> <ul

VUe.js 父组件向子组件中传值及方法

父组件向子组件中传值 1.  Vue实例可以看做是大的组件,那么在其内部定义的私有组件与这个实例之间就出现了父子组件的对应关系. 2. 父子组件在默认的情况下,子组件是无妨访问到父组件中的数据的,所以要想在子组件中使用父组件的数据的时候,就需要以属性绑定的形式,将父组件的数据传递到子组件中.     3. 通过属性绑定传递来的数据无法再子组件中直接使用,需要在props中重新定义以后才可以使用.例:props:['变量名'].props是一个数组.    4. 子组件中的data数据都是私有,子

vue组件中的通信

一.组件间的关系 1.父子关系 2.兄弟关系 3.隔代关系 二.组件间的通信方式 1.props 2.$emit/$on 3.VUEX 4.$parent/$children 5.$attrs/$listeners 6.provide/inject 三.通信方式举例 新建了一个过程,采用webpack来管理项目.  方法一:props / $emit 1.props---父组件向子组件传值 子组件:sub1.vue 父组件:app.vue 父组件通过props向下传递给子组件.注:组件中的数据共

iview修改table组件实现循环向上滚屏

前提,最近项目中需要实现table的滚屏效果,并且使用的是iview的table组件,踩坑,填坑如下. 1.首先找到Table组件中的table,就是这个class:ivu-table-body template部分代码 1 div class="headcol" > 2 <Table border :columns="columns7" :data="data6" ></Table> 3 </div>

在 iView 的组件中使用 Render 函数渲染内容,可以通过设置 class 属性来自定义样式

下图所示一个Table组件的表头的 Render 内容,对其中的Checkbox组件设置名为 my-favor-features-checkbox 的 class 样式: 比如:下面的CSS将能够改变该 CheckBox 组件实例在 disabled 时的样式: 值得一提的是:通过给某个组件实例自定义一个独一无二的 class 样式名,即可以单独修改这个组件实例的样式,同时不影响当前项目中同类型的其它组件实例的样式,从页做到了样式的个性化. 原文地址:https://www.cnblogs.co

vue(ref父组件使用子组件中定义的方法)

一.前言 二.主要内容 1.实现效果(其实可以直接在父组件中操作子组件的显示隐藏,但是这里通过在子组件定义自己的显示隐藏效果,让父组件调用,训练一下这种方式) 2.分析: (1)点击父组件的某一个li项,跳出这个商品详情(子组件项) (2)子组件中还是需要接收到父组件中的food,但是这个food不像上一篇那样是固定的,所以这里的这个food是根据我们点击的不同的项,传进去的 (3)为了实现上一步分析:我们需要在data中定义一个对象,点击的时候,将当前对象的food传进去,然后在传给子组件,这

[转] vue自定义组件中的v-model简单解释

在使用iview框架的时候,经常会看到组件用v-model双向绑定数据,与传统步骤父组件通过props传值子组件,子组件发送$emit来修改值相比,这种方式避免操作子组件的同时再操作父组件,显得子组件的封装效果更好.所以,个人认为,我们自己封装组件也应该有这样的思维,父组件通过slot或者props传值,由子组件完成一些效果,再抛出必要的事件让父组件接受,这样组件的可复用性就很强,有利于多次使用. v-model指令是什么? 刚刚提到,iview通过v-model双向绑定数据,所以首先我们要明白