当前位置: 首页 > news >正文

南京网站费用网站建设/百度公司招聘官网最新招聘

南京网站费用网站建设,百度公司招聘官网最新招聘,vs做网站用3层架构,网站开发 视频播放器什么是Hooks Hooks从语法上来说是一些函数。这些函数可以用于在函数组件中引入状态管理和生命周期方法。 React Hooks的优点 简洁 从语法上来说,写的代码少了上手非常简单 基于函数式编程理念,只需要掌握一些JavaScript基础知识与生命周期相关的知识不…

什么是Hooks

Hooks从语法上来说是一些函数。这些函数可以用于在函数组件中引入状态管理和生命周期方法。

React Hooks的优点

  1. 简洁
    从语法上来说,写的代码少了
  2. 上手非常简单
    • 基于函数式编程理念,只需要掌握一些JavaScript基础知识
    • 与生命周期相关的知识不用学,react Hooks使用全新的理念来管理组件的运作过程
    • 与HOC相关的知识不用学,React Hooks能够完美解决HOC想要解决的问题,并且更可靠
    • Mobx取代了Redux做状态管理
  3. 代码复用性更好
  4. 与Typescript结合更简单

React Hooks的缺点

  1. 状态不同步
    在异步操作的函数中访问的状态还是原来的状态的值
  2. useEffect依赖问题
    当useEffect依赖的数据变多后会导致频繁触发

React Hooks的注意事项

  1. 命名规范
    自定义Hooks的命名一律使用use作为前缀,形如:useXXX
  2. 仅在最外层调用React Hooks
  3. 仅从react函数中调用react Hooks
    在自定义Hooks或者组件中调用Hooks

ref hook

可以在函数式组件中存储/查找组件内的元素或其他数据

useRef

useRef(initialValue)返回一个可变的ref对象,该对象只有一个current属性,初始值为传入的参数initialValue,并且返回的ref对象在组件的整个生命周期内保持不变。

作用:

  • 用来获取DOM节点的实例,与React.createRef()作用一样
  • 存储渲染周期之间的共享数据
  1. 获取DOM节点的实例
import {useRef} from 'react'
function APP(){const userRef = useRef(null);const clickButton = ()=>{if(userRef.current){console.log(userRef.current);}}return <div><input name="username" ref={userRef} /><button onClick={clickButton}>show</button></div>
}
  1. 存储共享数据
    import {useRef,useState} from 'react'
    function APP(){const [count,setCount] = useState(0);const countRef = useRef(null);const preCount = countRef.current;useEffect(()=>{countRef.current = count;});const clickButton = ()=>{setCount(count+1);}return <div><input name="username" /><button onClick={clickButton}>show</button></div>
    }
    
注意事项
  1. 组件的每次渲染,useRef的返回值都不变
  2. ref.current发生变化并不会造成重新渲染
  3. 不可以在render中更新ref.current的值,否则会导致ref.current的值计算错误
    这是因为当其他的数据发生变化时,会导致重新渲染,这时ref.current会更新,这就导致计算错误。
  4. 元素属性的ref的值不能是useRef返回的对象以外的值
  5. ref.current的值发生变化不会触发useEffect
forwardRef

当ref作用在一个函数式组件上时不会获取到组件实例。因此需要使用forwardRef。

forwardRef会创建一个React组件,这个组件能够将其接收的ref属性转发到自己的组件树。

forwardRef()的用法是包裹一个组件。

import {forwardRef,useRef,useEffect} from 'react'
const Child = forwardRef((props,ref)=>{return <input ref={ref} type="text" />
});
function App(){const childRef = useRef(null);useEffect(()=>{childRef.current.focus();});return <><Child ref={childRef}></Child></>
}
useImperativeHandle

useImperativeHandle允许组件自定义需要暴露的ref数据,是为了解决useRef获取到组件的所有属性和方法的问题。

useImperativeHandle(ref,handle,[deps]):

  • ref:需要暴露的ref引用
  • handle:是一个函数,返回值会作为ref.current的值
  • deps:依赖数据,需要监听的状态
import {useRef,useImperativeHandle,forwardRef} from 'react'
const Child = forwardRef((props,ref){useImperativeHandle(ref,()=>{return {focus:()=>ref.current.focus()}},[props.value]);retunr <input ref={ref} value={props.value} />
});
function App(){const childRef = useRef(null);return <><Child ref={childRef}></Child></>
}
注意事项
  • useImperativeHandle和React.forwardRef必须配合使用,否则在运行的时候会直接报错。
  • 使用useImperativeHandle后,可以让父、子组件分别有自己的ref,通过React.forwardRef将父组件的ref传递过来,通过useImperativeHandle方法来自定义开放给父组件的current。
http://www.rdtb.cn/news/791.html

相关文章:

  • 网站添加二级域名/网络营销的几种模式
  • 山东省建设执业师之家官方网站/小广告网站
  • 站长工具怎么关掉/推广员是干什么的
  • 在深圳做网站平台需要什么备案/杭州优化建筑设计
  • 陕西省经营性网站备案/外链工具xg下载
  • 网站源码建站教程/58网络推广
  • 珠海市城乡规划建设局网站/新闻稿
  • wordpress文章爬取/合肥网站关键词优化公司
  • 网站建设公司中心/win7最好的优化软件
  • wordpress 免费博客/seo优化费用
  • 平台建站/抖音seo优化系统招商
  • o2o苗木网站建设/凡科网建站系统源码
  • html5手机网站/app拉新推广代理
  • 私密浏览器有哪些/宁波网站优化公司哪家好
  • 自己的网站怎么做进销存/注册公司流程和费用
  • php做的网站优缺点/推广怎么推
  • 六安网站制作/建站公司最新报价
  • 基本的网站建设知识/搜索引擎排名竞价
  • 高端网站设计v芯hyhyk1推好/百度seo关键词
  • 拍卖网站怎么做/上海百度分公司电话
  • wordpress 萝莉/seo信息查询
  • 网站建设销售怎样/google官网入口
  • 株洲手机网站建设/信息流广告加盟代理
  • 网站建设解决问题/网络外包
  • 管理系统前端模板/seo推广招聘
  • 做网站的公司 成都/扬州seo博客
  • 临沂网站公司哪家好/天津做优化好的公司
  • 做网批有专门的网站吗?/seo怎么读
  • 为什么网站要用外链/精准营销平台
  • 郑州做响应式网站/百度刷排名seo软件