博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Refs
阅读量:6324 次
发布时间:2019-06-22

本文共 1798 字,大约阅读时间需要 5 分钟。

Refs提供了一种访问
DOM节点或在
render方法中创建的
React元素的方法。

refs React组件中非常特殊的props,可以附加在任何一个组件上。组件被调用时会新建一个该组件的实例,而refs就会指向这个实例。

react\lib\ReactBaseClasses.js文件中,可以看出每个组件都存在refs属性。

/** * Base class helpers for the updating state of a component. */function ReactComponent(props, context, updater) {  this.props = props;  this.context = context;  this.refs = emptyObject;  // We initialize the default updater but the real one gets injected by the  // renderer.  this.updater = updater || ReactNoopUpdateQueue;}

在React组件上添加refs

1.使用字符串的方式添加refs

格式:ref='string'

import React, { Component } from 'react';import './App.css';import ReactDOM from 'react-dom';class Children extends Component {  render() {    return 
子组件
}}class App extends Component {s render() { return (
{/* 使用字符串方式 */}
); } componentDidMount() { console.log(this); console.log('*******************************'); console.log(this.refs.children); }}

输出结果:

在这里插入图片描述

refs 可以是字符串,同样可以是回调函数。

2.使用 回调函数 的方式添加refs

render方法修改如下:

render() {    return (      
{/* 使用字符串方式 */} {/*
*/} {/* 使用回调函数方式 */}
this.childrenRef=ref} />
); }

在这里插入图片描述

想要获取当前React组件的实例(引用)可以使用this,获取所拥有子组件的实例(引用)可以使用refs

React组件上添加refs,获取到的是组件的实例。而如果在原生的Dom组件上添加refs获取到的事什么呢?接着看

在DOM元素上添加refs

class App extends Component {  constructor(props){    super(props);  }  render() {    return (      
); } componentDidMount() { console.log(this); console.log('*******************************'); console.log(this.refs.input); }}

结果如下:

在这里插入图片描述

使用回调函数同理,获取到的都是DOM节点。

Refs 和函数组件

refs无法应用于函数组件(无状态组件),因为函数组件挂载时只是方法调用,没有新建实例。

如果需要引用它,则应该将组件转换为类,就像您需要生命周期方法或状态时一样。

但是,只要引用DOM元素或类组件,就可以在函数组件中使用ref属性

参考文档

《深入React技术栈》

转载地址:http://pvmaa.baihongyu.com/

你可能感兴趣的文章
.Net 垃圾回收和大对象处理 内存碎片整理
查看>>
Linux是如何启动的
查看>>
HiKey连接
查看>>
wget 参数大全
查看>>
使用Loadrunner进行文件的上传和下载
查看>>
Linux C 静态库(.a) 与 动态库(.so) 的详解
查看>>
JS函数
查看>>
sql语句分组/排序/计算总数/连接等sql语句书写
查看>>
【.net 深呼吸】启动一个进程并实时获取状态信息
查看>>
MVC5 的MicrosoftOwinSecurity扩展插件——微信,QQ登录第三方源码
查看>>
分布式系统理论基础 - CAP
查看>>
mysql 用户管理和权限设置
查看>>
【项目管理和构建】十分钟教程,eclipse配置maven + 创建maven项目
查看>>
[转]Asp.Net大型项目实践(11)-基于MVC Action粒度的权限管理【续】【源码在这里】(在线demo,全部源码)...
查看>>
Numpy 的ndarray
查看>>
牛人博客 列表
查看>>
数据库连接池dataesoruce pool深入理解
查看>>
vuejs2.0使用Sortable.js实现的拖拽功能
查看>>
oracle多实例的启动与关闭
查看>>
码农生涯杂记_4
查看>>