react扩展

1.refHook

类组件的ref定义。

​编辑

​编辑

两种方式一种是直接回调函数设置一个this.***Node节点=event,event为当前ref所在的标签元素,另一种是直接通过React.createRef方法去创建一个myRef在this实例对象中,然后直接ref={this.myRef}

函数组件和类组件第二种基本上一致

​编辑

通过React.useRef创建一个ref对象,然后在标签里面添加。

2.fragment(翻译碎片)

​编辑

​编辑

Fragment标签不会被渲染成真实Dom,而且只有一个属性key值(如果需要被遍历的情况下也可以使用)

和直接<></>包裹效果一样,但是遍历的时候需要用Fragment的key。

3.context

​编辑

我们有时候希望祖父组件给孙子组件传参数,如果用props一层层的传很繁琐,这时候需要用到context,相当于一个简便化的redux。

首先用React.createContext()定义一个Mycontext方法,解构赋值从里面拿出Provider以及Consumer两个方法。

用Provider包裹子组件,然后传递的参数是value={}这种格式,这样B组件以及B组件的子组件就可以拿到value里面的参数了,但是用之前需要声明接收。

类组件用static contextType = Mycontext,然后可以通过this.context拿到value对象。

函数组件用Consumer方法,

​编辑

用图片里面的Consumer标签包裹然后js表达式里面用参数为value的箭头函数返回我们想要展示的value对象中的数据。

4.PureComponent(组件优化)

我们在使用组件的时候,在更改一些父组件的状态后,会重新调用所有子组件的render去刷新然后重新渲染组件,这是非常多余的行为,我们通过下面的代码去优化。

​编辑

我们用shouldComponentUpdata中的参数nextProps与nextState和this.state以及this.props是否相同来判断是否取执行更新组件重新调用render。也可以直接用PureComponent自动封装了判断是否updata重新渲染render。

一个小重点是,当我们在使用setState的时候,我们必须更新的时候去拿一个新生成的state对象去合并更新,如果我们直接用unshitf或者const obj =

​编辑

这种图片里面的方式更新,直接去修改了原来的state,但是这时候地址是没有变化的,所以与({})效果一样,认为地址没变,返回的还是原来的state。

5.renderProps

​编辑

我们通常在A组件添加子组件直接用闭合标签去添加之后在调用A组件的时候会自动渲染调用B组件的render然后渲染到页面上,现在我们可以用这种作为children传过去使用,但是这种无法传A组件里面的props给B组件,所以我们用另一种方法<A/render={(value)=>{return({value})}}>,然后传一个B组件作为render函数的返回值,以及可以调用的时候传参数过去。

相关推荐
wuhen_n1 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端1 小时前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛1 小时前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦1 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU7290351 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
-凌凌漆-1 小时前
【npm】npm的-D选项介绍
前端·npm·node.js
鹿心肺语2 小时前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
海石2 小时前
去到比北方更北的地方—2025年终总结
前端·ai编程·年终总结
一个懒人懒人2 小时前
Promise async/await与fetch的概念
前端·javascript·html
Mintopia2 小时前
Web 安全与反编译源码下的权限设计:构筑前后端一致的防护体系
前端·安全