react-05-slot-插槽

简介: slot 插槽 在 vue里就常用react的插槽其实也一样还是模拟一个消息框 类似 elemetui 或者 iview message组件的形式

1. 前言


slot 插槽 在 vue里就常用

react的插槽其实也一样

还是模拟一个消息框 类似 elemetui 或者 iview   message组件的形式


2. 不用插槽之前

核心代码


function Message(props) {
            return (
                <div className="msgBox">
                    <div> {props.txt}  <span> x </span> </div>
                </div>
            )
        }
        ReactDOM.render((<div>
           <Message  txt="这是一个消息提示" />
        </div>), app)


简单样式


.msgBox {
            background-color: #67C23A;
            padding: 5px 20px;
            color: #FFF;
            border-radius:5px;
        }
 .msgBox span{
            float:right;
            color: #DCDFE6;
        }

简易效果

I68I5N%%GZGK_$)_G]_SR`P.png

1.png


3.slot


注意看看这个 参数 props


function Message(props) {
            console.log("瞅瞅这个props 到底是啥:",props)
            return (
                <div className="msgBox">
                    <div> {props.children} <span> x </span></div>
                </div>
            )
        }
        ReactDOM.render((<div>
           <Message>  这确实是个消息提示 </Message>
        </div>), app)

props

P%EZ6D7ZQ]OWX1L]RLCJFAS.png

1.png

不加标签 直接就是 字符串内容 {children: "XXXXX "}


4. 一个标签


核心代码


function Message(props) {
            console.log("瞅瞅这个props 到底是啥:",props)
            return (
                <div className="msgBox">
                    <div> {props.children} <span> x </span></div>
                </div>
            )
        }
            var title = "这是个消息"
        ReactDOM.render((<div>
           <Message><p>{title}</p></Message>
        </div>), app)

props

4(Z_6L)_~FK8$0{]SVKPEX0.png

1.png

单个标签是对象     {children: {…}}



5. 多个标签


核心代码


function Message(props) {
            console.log("瞅瞅这个props 到底是啥:",props)
            return (
                <div className="msgBox">
                    <div> 
                     <h1> {props.children[0]}</h1>  
                          {props.children[1]}
                        <span> x </span>
                        </div>
                </div>
            )
        }
            var title = "温馨提示"
        ReactDOM.render((<div>
           <Message>
            <p>{title}</p>
            <p> 这是一个好消息</p>
            </Message>
        </div>), app)

界面效果 以及 props

SRTI9)S9`O32IZJLOHWE4`4.png

1.png

多个是数组     {children: Array(2)}


6. children自动展开


如果不需要额外的样式,可以直接写, 因为这个数组在 react 里会自动展开


function Message(props) {
            console.log("瞅瞅这个props 到底是啥:",props)
            return (
                <div className="msgBox">
                    <div> 
                     {props.children}
                        <span> x </span>
                    </div>
                </div>
            )
        }



7.总结



children
      不加标签 直接就是 字符串内容 {children: " xxx "}
      单个标签是对象     {children: {…}}
      多个是数组     {children: Array(2)}




相关文章
|
6月前
|
前端开发 JavaScript 开发者
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
105 2
|
6月前
react18 实现具名插槽
react18 实现具名插槽
65 0
|
3月前
|
前端开发 JavaScript 开发者
深入理解React Hooks:提升前端开发效率的关键
【10月更文挑战第5天】深入理解React Hooks:提升前端开发效率的关键
|
2月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
101 9
|
3月前
|
前端开发
深入解析React Hooks:构建高效且可维护的前端应用
本文将带你走进React Hooks的世界,探索这一革新特性如何改变我们构建React组件的方式。通过分析Hooks的核心概念、使用方法和最佳实践,文章旨在帮助你充分利用Hooks来提高开发效率,编写更简洁、更可维护的前端代码。我们将通过实际代码示例,深入了解useState、useEffect等常用Hooks的内部工作原理,并探讨如何自定义Hooks以复用逻辑。
|
3月前
|
前端开发 JavaScript API
探索React Hooks:前端开发的革命性工具
【10月更文挑战第5天】探索React Hooks:前端开发的革命性工具
|
2月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
234 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
2月前
|
前端开发 JavaScript 开发者
使用React和Redux构建高效的前端应用
使用React和Redux构建高效的前端应用
60 1
|
3月前
|
前端开发 数据管理 编译器
引领前端未来:React 19的重大更新与实战指南🚀
React 19 即将发布,带来一系列革命性的新功能,旨在简化开发过程并显著提升性能。本文介绍了 React 19 的核心功能,如自动优化重新渲染的 React 编译器、加速初始加载的服务器组件、简化表单处理的 Actions、无缝集成的 Web 组件,以及文档元数据的直接管理。这些新功能通过自动化、优化和增强用户体验,帮助开发者构建更高效的 Web 应用程序。
236 1
引领前端未来:React 19的重大更新与实战指南🚀
|
2月前
|
前端开发 JavaScript Android开发
前端框架趋势:React Native在跨平台开发中的优势与挑战
【10月更文挑战第27天】React Native 是跨平台开发领域的佼佼者,凭借其独特的跨平台能力和高效的开发体验,成为许多开发者的首选。本文探讨了 React Native 的优势与挑战,包括跨平台开发能力、原生组件渲染、性能优化及调试复杂性等问题,并通过代码示例展示了其实际应用。
82 2