React Native:发现默认参数children【特殊的prop】

根据react中文网教程:添加交互 -- React 中文文档

其中添加交互的响应事件部分有一段代码

代码如下:

javascript 复制代码
export default function App() {
  return (
    <Toolbar
      onPlayMovie={() => alert('Playing!')}
      onUploadImage={() => alert('Uploading!')}
    />
  );
}

function Toolbar({ onPlayMovie, onUploadImage }) {
  return (
    <div>
      <Button onClick={onPlayMovie}>
        Play Movie 
      </Button>
      <Button onClick={onUploadImage}>
        Upload Image
      </Button>
    </div>
  );
}

function Button({ onClick, children }) {
  return (
    <button onClick={onClick}>
      {children}
    </button>
  );
}

呈现出来的效果如下:

这段代码有意思的地方就是,函数组件Button明明需要两个声明的参数,但是ToolBar组件嵌套时只传递了一个第一个参数onClick。而第二个函数children竟然默认是组件中的文本内容也许是我大惊小怪,但在其他的编程语言里面确实没见过,这么灵活的设计,不亲自实践或者有教程可以看到应该不容易理解和发现吧。而且这个参数名称只能是children,不能是其它的命名的,我试过时不好使的。

相关推荐
兆子龙1 天前
ahooks useRequest 深度解析:一个 Hook 搞定所有请求
java·javascript
兆子龙1 天前
React Suspense 从入门到实战:让异步加载更优雅
java·javascript
sure2821 天前
React Native中创建自定义渐变色
前端·react native
KKKK1 天前
SSE(Server-Sent Events)流式传输原理和XStream实践
前端·javascript
墨狂之逸才1 天前
React Native 物理按键扫码监听终极方案:从冲突到完美共存
react native
子兮曰1 天前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端
Din1 天前
主动取消的防抖
前端·javascript·typescript
H5开发新纪元1 天前
Nginx 部署 Vue3 项目完整指南
前端·javascript·面试
决斗小饼干1 天前
跨语言移植手记:把 TypeScript 的 Codex SDK 请进 .NET 世界
前端·javascript·typescript