ref可以获取dom节点或者react元素的实例,一般有三种使用方法
1. string ref
data:image/s3,"s3://crabby-images/05ff1/05ff1efac23f8e3dc9442b5d0474142949567ae0" alt=""
使用方法就是在react元素上使用一个ref属性,然后传入一个字符串,最后react在完成这个节点的渲染之后,就会在this.ref这个对象上增加一个这个字符串的key,这个key对应的value就是这个react元素的实例。如果是一个function component则会报错。如果要对function component使用ref,就必须把function component用forwardRef给包起来
data:image/s3,"s3://crabby-images/91a84/91a84bc45b0d9b38d75939769d619bc22cf4935d" alt=""
2. function
data:image/s3,"s3://crabby-images/204dd/204dd19c57526eaf968d04d0845c5c2956ef7244" alt=""
3. createRef
data:image/s3,"s3://crabby-images/2efb3/2efb321e4a486e9657d0dd45ac423ceba3e35b74" alt=""
createRef会创建一个对象,这个对象默认值是
{current: null}
,把这个this.objRef放到ref属性里后,这个节点对应的实例就会挂载到这个对象的current上。
网友评论