render 函数渲染表格的当前数据列使用

实例1:

columns7: [
// 实例1:代码段
{
title: '编号',
align: 'center',
width: 90,
key: 'No',
render: (h, params) => {
return h('p', {
style: 'color:#2D8CF0;font-size:14px;cursor: pointer;',
on: {
'click': () => {
this.GotoPage(params.row)
}
}
}, params.row.No)
}
},
// 实例2代码段: 未写成组件前
{
title: '个数',
align: 'center',
width: 100,
key: 'popupArr',
render: (h, params) => {
let arrData = params.row.SumArr
let rowData = []
// 弹窗内容处理
let popupCon = []
if (params.row.popupArr.length){
popupCon = [
h('p', {}, `个数: ${params.row.popupArr.length}`),
h('p', {}, [
h('span', {class: 'pop-span1'}, '金额'),
h('span', {class: 'pop-span3'}, '号码')
])
]
params.row.popupArr.map(items => {
let money = null
money = h('p', {}, [
h('span', {class: 'pop-span1'}, `¥${this.numberComma(Number(items.Amount).toFixed(2))}`),
h('span', {class: 'pop-span2'}, `${items.Number}`)
])
popupCon.push(money)
})
}
// 外层内容
arrData.map((item, index) => {
// 单元格行的内容
// on-popper-show 为监听事件,鼠标移上去请求接口拿数据展示在浮窗中
let rowsC = null
let tooltip = []
        // Tooltip
tooltip[0] = h('Tooltip', {
props: {placement: 'left', 'delay': 700, 'max-width': '600'},
on: {
'on-popper-show': () => {
this.PopperShow(h, params)
}
}
}, [
h('p', {style: 'min-width: 70px;'}, item.Count),
h('div', {slot: 'content'}, popupCon)
])
// 小单元格外层框
if (index + 1 === arrData.length) {
rowsC = h('p', {
style: 'padding:0 0 0 0;height:40px;line-height:40px;'
}, tooltip)
} else {
rowsC = h('p', {
style: 'padding:0 0 0 0;height:40px;line-height:40px;border-bottom: 1px solid #E8EAEC;'
}, tooltip)
}
rowData.push(rowsC)
})
return h('div', {class: 'countCol'}, rowData)
}
},
] // 方法
methods: {
 PopperShow (h, params) {
// 请求接口已封装
this.$store.dispatch('GetInvoicedInfo', params.row.Id).then((res) => {
     if (res.Result) {
       this.$nextTick(() => {
       params.row.popupArr = res.Data
       this.$forceUpdate()
     })
   }
})
  }
}

  

实例2:

render: Tooltip 动态获取浮窗数据的实例

以上代码我们可以优化下,将浮窗Tooltip写成公共组件的方式,在render中引入该模板组件:

columns7: [
{
title: '个数',
align: 'center',
width: 100,
key: 'popupArr',
render: (h, params) => {
let arrData = params.row.SumArr
let rowData = []// 外层内容
arrData.map((item, index) => {
// 单元格行的内容
// on-popper-show 为监听事件,鼠标移上去请求接口拿数据展示在浮窗中
let rowsC = null
let tooltip = []
        // Tooltip
          tooltip[0] = h(vInfoTooltip, {
            props: {
              placement: 'left',
              rowId: params.row.Id,
              dataNo: item.No
            },
            slot: 'content'
          }, [
            h('p', {
              style: 'min-width: 70px;',
              slot: 'infoTooltip'
            }, [
              h('span', {
                style: 'color: rgb(45, 140, 240);cursor: pointer;font-size:14px;',
                slot: 'content'
              }, item.Count)
            ])
          ])
        // 小单元格外层框
if (index + 1 === arrData.length) {
rowsC = h('p', {
style: 'padding:0 0 0 0;height:40px;line-height:40px;'
}, tooltip)
} else {
rowsC = h('p', {
style: 'padding:0 0 0 0;height:40px;line-height:40px;border-bottom: 1px solid #E8EAEC;'
}, tooltip)
}
rowData.push(rowsC)
})
return h('div', {class: 'countCol'}, rowData)
}
},
]

InfoTooltip.vue

<template>
<div class="InfoTooltip">
<Tooltip :placement="placement" :delay="700" @on-popper-show="PopperShow" @on-popper-hide="PopperHide" max-width="600">
<slot name="infoTooltip"></slot> <!-- 该内容即 鼠标移上去的内容 -->
<div class="demo-InfoList" slot="content"> <!-- 该div内的内容即为 浮窗的内容 -->
<p>个数: {{InfoList.length}}</p>
<p>
<span class="pop-span1">金额</span>
<span class="pop-span2">号码</span>
<span class="pop-span3">状态</span>
</p>
<p v-for="(items, index) in InfoList" :key="index">
<span class="pop-span1">¥{{numberComma(Number(items.Amount).toFixed(2))}}</span>
<span class="pop-span2">{{items.Number}}</span>
<span class="pop-span3">{{items.Status}}</span>
</p>
</div>
</Tooltip>
</div>
</template>
<script>
export default {
name: 'InfoTooltip',
components: {
},
data () {
return {
InfoList: []
}
},
props: {
rowId: String,
dataNo: String,
placement: {
type: String,
default: 'right-start'
}
},
created () {
},
computed: {
},
methods: {
GetPopupArrFn (arrData, dataNo) {
let obj = {}
arrData.map(function (item) {
let timeKey = item.InvoDate.split(' ')[0]
if (!obj[timeKey]) {
obj[timeKey] = []
}
obj[timeKey].push(item)
})
return obj[dataNo]
},
PopperHide () {
},
PopperShow () {
this.$store.dispatch('GetInvoicedInfo', this.rowId).then((res) => {
if (res.Result) {
this.$nextTick(() => {
this.InfoList = this.GetPopupArrFn(res.Data, this.dataNo)
})
}
})
}
}
}
</script> <style scoped lang="less">
.demo-InfoList {
display: inline-table;
p {
float: left;
width: 100%;
line-height: 22px;
}
.pop-span1 {
width:120px;
display:inline-block;
}
.pop-span2{
width:200px;
display:inline-block;
}
.pop-span3{
width:80px;
display:inline-block;
text-align:center;
}
}
</style>

最后效果即如图:

鼠标移入小单元格时,动态请求浮窗内容

render 函数渲染表格的当前数据列使用的更多相关文章

  1. 使用render函数渲染组件

    使用render函数渲染组件:https://www.jianshu.com/p/27ec4467a66b

  2. 在vue中结合render函数渲染指定的组件到容器中

    1.demo 项目结构: index.html <!DOCTYPE html> <html> <head> <title>标题</title> ...

  3. iview,用render函数渲染

    <Table border :columns="discountColumns" :data="discountData.rows"></Ta ...

  4. 使用Python的Flask框架,结合Highchart,动态渲染图表(Ajax 请求数据接口)

    参考链接:https://www.highcharts.com.cn/docs/ajax 参考链接中的示例代码是使用php写的,这里改用python写. 需要注意的地方: 1.接口返回的数据格式,这个 ...

  5. render方法渲染组件和在webpack中导入vue

    使用component注册的组件div容器里可以放多个,但是使用render的只能放一个 <div id="app"> <p>我可以放两个</p> ...

  6. iview table表中使用render函数props传值出现问题

    使用iview中的table表格时避免不了使用render函数渲染自定义内容,或者渲染组件.但是在正常使用时出现了props传值无法识别, 按照官网介绍使用props如下: render: (h, p ...

  7. vue入门:(底层渲染实现render函数、实例生命周期)

    vue实例渲染的底层实现 vue实例生命周期 一.vue实例渲染的底层实现 1.1实例挂载 在vue中实例挂载有两种方法:第一种在实例化vue时以el属性实现,第二种是通过vue.$mount()方法 ...

  8. 超全table功能Datatables使用的填坑之旅--1: 无法渲染表格数据: ajax调用了参数 : success

    问题:Datatables: 无法渲染表格数据 原因:datatables的ajax 传了"success":function(){},导致无法渲染数据. ajax 删掉" ...

  9. oracle数据库查询日期sql语句(范例)、向已经建好的表格中添加一列属性并向该列添加数值、删除某一列的数据(一整列)

    先列上我的数据库表格: c_date(Date格式)     date_type(String格式) 2011-01-01                   0 2012-03-07         ...

随机推荐

  1. ES6,先知道这些必会的才行

    变量声明 const 和 let 不要用 var,而是用 const 和 let,分别表示常量和变量.不同于 var 的函数作用域,const 和 let 都是块级作用域. const DELAY = ...

  2. java TreeSet 实现存自定义不可重复数据

    本文主要是介绍一下java集合中的比较重要的Set接口下的可实现类TreeSet TreeSet类,底层用二叉树的数据结构 * 集合中以有序的方式插入和抽取元素. * 添加到TreeSet中的元素必须 ...

  3. 配置centos7 网卡

    进入root模式,输入 cd /etc/sysconfig/network-scripts/ 按Tab键查看网卡配置文件名称,然后进入编辑: 如: cd /etc/sysconfig/network- ...

  4. 原生js制作标题与内容保持4行的效果

    在制作网页或移动端有时会用到一个效果,类似文章标题和文章描述的排列总是保持一样的行数,要么标题总是一行,多出的省略,要么标题内容1:3或2:2或3:1这样,今天练习这样的效果. 实现的原理:给标题和内 ...

  5. 把连接中传的参数截取出来变成一个json对象

    获取url function test() { var url=window.location.search; if(url.indexOf("?")!=-1) { var str ...

  6. .NET开源工作流RoadFlow-Bug修改-1.8.2子流程接收者始终为发送者

    1.8.2及以前版本中子流程待办任务的处理者始终为上一步骤发送者BUG的处理: 修改类:RoadFlow.Platform.WorkFlowTask中如下图红框中的内容即可:

  7. Retrofit实现图文上传至服务器

    Retrofit实现图文上传至服务器 前言:现在大多数的项目中都涉及图片+文字上传了,下面请详见实现原理: 开发环境:AndroidStudio 1.引入依赖: compile 'com.square ...

  8. pt-query-digest(percona toolkit)小解

    pt-query-digest可以通过logs, processlist, 和tcpdump来分析MySQL的查询相关信息,基本语法如下: pt-query-digest [OPTIONS] [FIL ...

  9. GPDB 5.x PSQL Quick Reference

    General \copyright show PostgreSQL usage and distribution terms \g [FILE] or ; execute query (and se ...

  10. ASPNET MVC Error 403.14

    今天创建了一个新的ASPNET MVC 项目部署到本地, 生成成功后在浏览器中输入URL却发现报这个错 解决办法: 因为我的站点是4.5的,但是我没有设置Application Pool所以当前还是默 ...