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函数的返回值,以及可以调用的时候传参数过去。

相关推荐
陈随易15 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星15 小时前
javascript之事件代理/事件委托
前端
陈随易16 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
里欧跑得慢18 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒19 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
kyriewen19 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真19 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal19 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
竹林81820 小时前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding20 小时前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化