react08-插槽

react08 - 插槽

函数组件 - 插槽

解决在react18中的componentDidmonunt 执行两次的方法 : 将root.render() 中的 <React.StrictMode></ React.StrictMode> 的标签关闭

双闭合标签调用组件时,可以传递子节点,当只传递一个节点时,在组件中通过props结构出来的是一个节点对象,当有多个节点时获得的是一个数组,每个子节点就是一个数组的对象元素 :

当没有子节点时,打印的将是undefined,因为props中没有该属性

获得children后,怎么使用呢?

插槽的机制

插槽应用

手动处理有些麻烦,可以引入 React库 使用react对象中的Children方法 :

count : 子节点个数; foreach、map: 数组遍历; toArray : 转换成数组,无论什么结构的children值

具名插槽

很简单,就给插槽中的子节点加个 slot属性名

具名插槽用来处理这种子节点排序随意而导致页面显示异常的情况

slot就是一个随意的属性名,可以随意起,属性值可以用来给子节点分类,将向同类放入同一个数组中,以便后续处理,slot属性名和其属性值都可以用来给节点分类,只需注意在遍历children对象处理分类时别搞错就行

相关推荐
清羽_ls5 分钟前
前端代码CR小知识点汇总
前端·cr
WestWong7 分钟前
基于 Web 技术栈的跨端开发模版
前端
饮水机战神8 分钟前
小程序被下架后,我连夜加了个 "安全接口"
前端·javascript
小old弟8 分钟前
小程序开发:原生 vs 跨平台框架全解析
前端
閞杺哋笨小孩14 分钟前
Vue3 点击指令(防抖 / 节流)
前端·vue.js
加油吧zkf15 分钟前
Python入门:从零开始的完整学习指南
开发语言·前端·python
柯南二号21 分钟前
【大前端】 TypeScript vs JavaScript:全面对比与实践指南
前端·javascript·typescript
岁月宁静22 分钟前
AI 语音合成技术实践:实现文本转语音实时流式播放
前端·vue.js·node.js
用户19087228247825 分钟前
多段进度条解决方案
前端
閞杺哋笨小孩25 分钟前
Vue3 可拖动指令(draggable)
前端·vue.js