ViewUi的render

简介: ViewUi的render

需要:我们想要在table组件里面自定义一些内容,

比如select / switch 等等,就需要用到render这个函数

先看一下官网提供的例子:

      columns1: [
        {
          title: "Name",
          key: "name",
        },
        {
          title: "Age",
          key: "age",
        },
        {
          title: "Address",
          key: "address",

          render: (h, params) => {
            console.log(params);
            return h("i-switch", {
              props: {
                type: "radio",
                value: params.row.checked,
              },

              nativeOn: {
                click: () => {
                  this.initData();
                  console.log(123);
                },
              },
            });
          },
        },
      ],

复制代码
在表头里面直接render出来结构,写法比较奇葩,参考vue的render

https://cn.vuejs.org/v2/guide/render-function.html

效果图如下:

就可以看到我们自定义的组件switch了,

注意如果绑定的是一些第三方组件(ivewUI),

绑定事件需要 用nativeOn

两个参数:h类似于creatDom,params就是这一列的数据

包括column ,index,raw

当我们觉得恶心(render写法)且大功告成的时候,

发现render写法更恶心的地方!

视图无法更新

举例:我们开关的按钮需要调接口,然后不论请求成功或失败,

都需要再去获取一次最新的数据,来更新我们的视图。

用render的写法就会导致,数据源变了,视图却无法更新的问题。

参考了一些文档,发现可以用slot来替代render,解决我们问题的同时,

也让我们的写法更优雅了,写法如下:

    <i-table :columns="columns1" :data="data1">
      <!-- switch slot -->
      <template slot-scope="{ row, index }" slot="switchSlot">
        <i-switch v-model="row.checked" @on-change="initData"></i-switch>
      </template>
    </i-table>

复制代码
注意slot需要声明在table里面,不然报错

然后,再定义表头的columns1来引用slot 即可完成。

      columns1: [
        {
          title: "Name",
          key: "name",
        },
        {
          title: "Age",
          key: "age",
        },
        {
          title: "Address",
          key: "address",
          slot: "switchSlot",
          // render: (h, params) => {
          //   console.log(params);
          //   return h("i-switch", {
          //     props: {
          //       type: "radio",
          //       value: params.row.checked,
          //     },

          //     nativeOn: {
          //       click: () => {
          //         this.initData();
          //         console.log(123);
          //       },
          //     },
          //   });
          // },
        },
      ],

复制代码
代码注释了render的写法

相关参考文档:https://run.iviewui.com/8NNVisgQ

最后不得不说,iview真的坑,render写法真的恶心。。

作者: Bill 本文地址: http://biaoblog.cn/info?id=1625625191946

版权声明: 本文为原创文章,版权归 biaoblog 个人博客 所有,欢迎分享本文,转载请保留出处,谢谢!

相关文章
|
8月前
|
前端开发
react-router中的render、children、component
react-router中的render、children、component
270 1
|
3月前
|
JavaScript 开发者
Vue Render函数
【10月更文挑战第11天】 Vue 的 Render 函数提供了一种强大而灵活的方法来创建虚拟 DOM 节点,使开发者能够更精细地控制组件的构建过程。通过 `createElement` 参数,可以动态生成各种元素和组件,实现复杂逻辑和高级定制。尽管使用 Render 函数需要更多代码和对虚拟 DOM 的深入理解,但它在处理复杂场景时展现出巨大的优势。
27 2
|
3月前
|
JavaScript 开发者
Vue Render函数
【10月更文挑战第4天】
22 0
|
3月前
快速掌握 Svelte 的 Render 函数
【10月更文挑战第4天】
44 0
|
5月前
|
前端开发 测试技术
React 中 Render Prop 的概念
【8月更文挑战第31天】
39 0
|
JavaScript
vue: render 封装el-pagination
vue: render 封装el-pagination
120 0
|
8月前
|
前端开发
React中render Props模式
React中render Props模式
|
8月前
|
JavaScript 前端开发 API
Vue中的render函数和template渲染原理有什么不同?
Vue中的render函数和template渲染原理有什么不同?
191 0
|
8月前
|
前端开发 JavaScript
react的render什么时候渲染?
react的render什么时候渲染?
66 0
|
JavaScript 前端开发 安全
vue中的 render 和 h() 详解
当使用Vue.js进行前端开发时,理解和掌握&quot;render&quot;函数和&quot;h()&quot;函数是非常重要的,因为它们是Vue组件的核心构建和渲染部分 render 和 h()是在Vue.js中常用的两个概念,它们通常用于创建和渲染Vue组件。
363 0