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对象处理分类时别搞错就行

相关推荐
Mr_Mao2 小时前
Naive Ultra:中后台 Naive UI 增强组件库
前端
前端小趴菜054 小时前
React-React.memo-props比较机制
前端·javascript·react.js
摸鱼仙人~5 小时前
styled-components:现代React样式解决方案
前端·react.js·前端框架
sasaraku.5 小时前
serviceWorker缓存资源
前端
RadiumAg6 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo6 小时前
ES6笔记2
开发语言·前端·javascript
yanlele7 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
中微子8 小时前
React状态管理最佳实践
前端
烛阴8 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
中微子8 小时前
JavaScript 事件与 React 合成事件完全指南:从入门到精通
前端