vue+iview组件,render函数,table render Input,Tooltip,Select Option,Upload各种标签的render函数举例

iview 组件用法

iview render 函数

1.table render Input

render: (h, params) => {
    return h('Input',{
        props:{ //属性
            value: params.row.prizeName,
            maxlength: 8,
        },
        on: {
            'on-change':(e) => {
                this.tableData[params.index].prizeName = e.target.value;
            }
        }
    })
}

基础用法,没啥需要注意的,触发函数'on-change',更改时触发函数。

2.table render InputNumber

//render InputNumber
render:(h,params) => { //params为当前操作行的行数据内容
    return h('InputNumber',{
        style:{
            width:'50px'
        },
        props:{
            value: params.row.sort,
            min: 1, // InputNumber 最小值为1
        },
        on: {
            'on-change':(value) => { // 更改数据时触发函数
                this.tableData[params.index].sort = value;
            }
        }
    })
}

3.table render Select Option

//render Select Option
render: (h, params) => {
    return h('Select', {
        props:{
            value: params.row.prizeType,
            label: params.row.name,
        },
        on: {
            'on-change':(value) => {
                this.tableData[params.index].prizeType = value;
                this.getModeValue(value);
            }
        },
    },
        this.getModeList.map(function(row){
            return h('Option', {
                props: {
                    value: row.prizeType,
                    label: row.name,
                }
            }, row.name);
        })
    );
}

4.table render tooltip

//iview tooltip render
render: (h, params) => {
    return h('div', [
        h('Tooltip', {
            props: { placement: 'right' }
        }, [
            h('span', {
                style: {
                    display: 'inline-block',
                    width: params.column._width*0.85+'px',
                    overflow: 'hidden',
                    textOverflow: 'ellipsis',
                    whiteSpace: 'nowrap',
                },
            }, params.row.remark),
            h('span', {
                slot: 'content',
                style: { whiteSpace: 'normal', wordBreak: 'break-all' }
            }, params.row.remark)
        ])
    ])
}

内容超出表格宽度显示省略号,鼠标滑过显示tooltip。

5.table render upload 上传图片

render: (h, params) => {
    return h('div',[
        h('a',{
            on: {
                click: () => {
                    this.previewImg(params);
                }
            }
        },[
            h('img',{ //显示已上传图片
                attrs:{src:params.row.innerPrizeImg},
                style:{maxWidth:'40px',maxHeight:'30px', verticalAlign:'middle',marginRight: '10px'},
            })
        ]),
        h('Upload', {
            props: {
                type: 'select',
                action: '//127.0.0.1', // localhost 阻止上传
                'before-upload': this.uploadImg, //上传前调用函数
            },
            style: {
                display: 'inline-block',
                marginRight: '10px'
            },
        }, [
            h('Button',{
                props: {
                    type: 'primary',
                    size: 'small',
                },
                on: {
                    click: () => {
                        this.uploadFileChoose = params; // 赋值当前行参数,用于编写业务逻辑时使用
                    }
                }
            },'上传图片'),
        ]),
    ]);
}

uploadImg 上传图片函数

uploadImg(file) {
    let that = this;
    if (file.type.indexOf("image") === "-1") {
        that.$Message.error("文件类型不对!");
    } else if (file.size > 2097152 && file.size <= 0) {
        that.$Message.error("文件大小不能超过2M!");
    } else {
        try {
        let reader = new FileReader();
        reader.readAsDataURL(file)
        reader.onload = e => {
            let imgFile = e.target.result;
            let arr = imgFile.split(',');
            let url = "einsurance/uploadimage.do";
            let params = {
            "base64Str": arr[1],
            "imgUrl": "",
            "suffix": "",
            "ruleType": "_11_11",
            "businessNo": ""
            };
            that.$ajax_post(url, params, data => {
            if (data.ResultCode === "00") {
                that.uploadFileChoose.row.innerPrizeImg = data.data.innerUrl;
                that.uploadFileChoose.row.prizeImg = data.data.outerUrl;
            } else {
                that.$Message.error(data.Result.MSG);
            }
            })
        }
        } catch (error) {
        console.error("文件转码失败:", error)
        that.$Message.error("文件转码失败!");
        }
    }
    return false;
},

6.table render 上传excel表格文件 转成json传给后端

return h('Upload', {
    props: {
        type: 'select',
        action: '//127.0.0.1',
        'before-upload': this.uploadFile,
    },
    style: {
        display: 'inline',
        marginRight: '10px'
    },
}, [
    h('Button',{
        props: {
            type: 'primary',
            size: 'small',
        },
        style: {
            display: 'inline',
        },
        on: {
            click: () => {
                this.uploadXlsChoose = params; // 赋值当前行参数,用于编写业务逻辑时使用
            }
        }
    },'导入文件'),
]),

上传excel方法 uploadFile()

uploadFile(file) {
    var that = this;
    if(file.type.indexOf('excel') == -1){
        that.$Message.error('上传文件类型错误,请重新上传');
        return false;
    }
    this.file = file;
    var wb; //读取完成的数据
    var rABS = false; //是否将文件读取为二进制字符串
    var reader = new FileReader();
    reader.onload = function (e) {
        var data = e.target.result;
        if(rABS){
            wb = XLSX.read(btoa(fixdata(data)), {
                //手动转化
                type: "base64"
            });
        }else{
            wb = XLSX.read(data, {
                type: "binary"
            });
        }
        let prizeInfo = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);
        // console.log(prizeInfo); // 表格内容
        let prizeList = [];
        for(var i in prizeInfo){
            let prizeObj = {
                prizeCode: prizeInfo[i].key, //表格内容键值
                prizeNo: prizeInfo[i].key, //表格内容键值
            }
            prizeList.push(prizeObj);
        }
        let url = "einsurance/importprizecode.do"
        let params = { // 业务逻辑需要传输的参数, prizeCodeList为表格内容json
            "activityId": that.uploadXlsChoose.row.activityId,
            "prizeId": that.uploadXlsChoose.row.prizeId,
            "prizeCodeList": prizeList,
        }
        that.$ajax_post(url,params,data => {
            if(data.ResultCode == '00'){
                that.$Message.success({
                    content: `${data.data}`,
                    duration: 5,
                });
                that.reload();
            }
        });
    };
    if (rABS) {
        reader.readAsArrayBuffer(this.file);
    } else {
        reader.readAsBinaryString(this.file);
    }
    return false;
},

1.日期控件双向绑定

//日期控件双向绑定 用 :value
<DatePicker type="datetimerange" @on-change="changeDate" :value="activityTime" format="yyyy-MM-dd HH:mm:ss" placeholder="选择活动时间" style="width:100%"></DatePicker>

2.select option 赋值

//select option 赋值
<Select v-model="typeSelect" placeholder="请选择活动类型">
    <Option v-for="item in activityTypeList" :key="item.value" :value="item.value">{{ item.label }}</Option>
</Select>
activityTypeList: [ //活动类型 select
    {
        value: '1',
        label: '月抽越旺',
    },
],
//当 Select 的 typeSelect = this.activityTypeList[0].value 时,默认选中该值
this.typeSelect = this.activityTypeList[0].value;

3.table 过滤状态值

//iview 过滤状态值写法
render: (h,params) => {
    let statusDes = '';
    if(params.row.status == 0){
        statusDes = '待上架'
    }else if(params.row.status == 1){
        statusDes = '已上架'
    }else if(params.row.status == 2){
        statusDes = '已下架'
    }
    return h('span',statusDes);
},
filters: [
    {
        label: '已上架',
        value: 1
    },
    {
        label: '待上架',
        value: 0
    },
    {
        label: '已下架',
        value: 2
    }
],
filterMultiple: false,
filterMethod (value, row) {
    return row.status.toString().indexOf(value) > -1;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容