模仿elementui的Table,实现思路

vue2子组件使用render,给子子组件插槽传值

和elementui的Table一样使用render

在 Vue 2 中,子组件使用render函数向子子组件插槽传值可以通过以下步骤实现:

1、创建子组件

首先创建一个子组件,在子组件中使用render函数来渲染内容。在render函数中,可以通过this. s l o t s . d e f a u l t 获取父组件传递过来的默认插槽内容,通过 t h i s . slots.default获取父组件传递过来的默认插槽内容,通过this. slots.default获取父组件传递过来的默认插槽内容,通过this.scopedSlots获取父组件传递过来的具名插槽内容。

bash 复制代码
Vue.component('child-component', {
  render: function (createElement) {
    // 获取父组件传递的默认插槽内容
    var defaultSlot = this.$slots.default;
    // 获取父组件传递的具名插槽内容
    var namedSlot = this.$scopedSlots && this.$scopedSlots.slotName;
    return createElement('div', [
      createElement('p', '这是子组件'),
      // 渲染默认插槽内容
      defaultSlot,
      // 渲染具名插槽内容
      namedSlot && namedSlot()
    ]);
  }
});

2、创建子子组件

创建一个子子组件,该组件接收一个prop属性来获取父组件传递的值。

bash 复制代码
Vue.component('sub-child-component', {
  props: ['message'],
  template: '<div>{{ message }}</div>'
});

3、使用子组件和子子组件

在父组件中使用子组件,并通过插槽向子组件传递内容。在子组件中,通过this. s l o t s . d e f a u l t 或 t h i s . slots.default或this. slots.default或this.scopedSlots获取插槽内容,并将其传递给子子组件。

bash 复制代码
<div id="app">
  <child-component>
    <sub-child-component slot="slotName" message="这是传递给子子组件的值"></sub-child-component>
  </child-component>
</div>
相关推荐
Python大数据分析@15 分钟前
通俗的讲,网络爬虫到底是什么?
前端·爬虫·网络爬虫
Lysun00136 分钟前
vue2的$el.querySelector在vue3中怎么写
前端·javascript·vue.js
jerry-891 小时前
Centos类型服务器等保测评整/etc/pam.d/system-auth
java·前端·github
小爬菜1 小时前
Django学习笔记(启动项目)-03
前端·笔记·python·学习·django
想要打 Acm 的小周同学呀1 小时前
前端Vue2项目使用md编辑器
前端·编辑器·vue2·markdown 语法
计算机-秋大田1 小时前
基于SSM的家庭记账本小程序设计与实现(LW+源码+讲解)
java·前端·后端·微信小程序·小程序·课程设计
海的预约2 小时前
VUE之路由Props、replace、编程式路由导航、重定向
前端·vue.js·智能路由器
西柚与蓝莓3 小时前
报错:{‘csrf_token‘: [‘The CSRF token is missing.‘]}
前端·flask
德迅云安全-小钱4 小时前
跨站脚本攻击(XSS)原理及防护方案
前端·网络·xss
ss2734 小时前
【2025小年源码免费送】
前端·后端