react refs

react refs

允许我们访问DOM节点或者在render方法中创建react元素;
本质为reactDOM.render()返回的组件实例,如果是渲染组件则返回的是组件实例;如果渲染dom则返回的是具体的dom节点。

使用:

创建ref的形式有三种:

  • 传入字符串,使用时通过this.refs传入的字符串的格式获取对应的元素
  • 传入对象,对象是通过 React.createRef()方式创建出来的,使用时获取到创建的对象中存在current属性就是对应的元素
  • 传入函数,该函数会在 DOM 被挂载时进行回调,这个函数会传入一个元素对象,可以自己保存,使用时直接拿到之前保存的元素对象即可
  • 传入hook,hook是通过 useRef() 方式创建,使用时通过生成hook对象的current属性就是对应的元素
传入字符串

只需要在对应元素或组件中使用 ref 属性

	class MyComponent extends React.Component {
		 constructor(props) {
			 super(props);
			 this.myRef = React.createRef();
		 }
		 render() {
		 	return <div ref="myref" />;
		 }
	}

访问当前节点:

	this.refs.myref.innerHTML = "hello";
传入对象

refs通过React.createRef()创建,将ref属性添加到react元素中:

	class MyComponent extends React.Component {
		 constructor(props) {
			 super(props);
			 this.myRef = React.createRef();
		 }
		 render() {
		 	return <div ref={this.myRef} />;
		 }
	}

ref被传递给render中的元素是,对节点的引用可以在refcurrent属性中访问:

	const node = this.myRef.current;
传入hook

通过useRef 创建一个ref,整体使用方式与React.createRef一致

	function App(props) {
		 const myref = useRef()
		 return (
			 <>
			 <div ref={myref}></div>
			 </>
		 )
	}

获取ref属性也是通过hook对象的current属性

	const node = myref.current;

上述三种情况都是ref属性用于原生HTML元素上,如果ref设置的组件为一个类组件,ref对象接收到的是组件的挂在实例

注意:不能在函数组件上使用ref属性,因为他们并没有实例

应用场景

在某些情况下,我们会通过使用refs来更新组件,但是这种方式并不推荐,更多情况是通过propsstate的方式进行重新渲染子组件
过多使用refs,会使组件的实例或者DOM结构暴露,违反组件封装的原则
例如:避免在Dialog组件里暴露open() close()方法,最好传递isOpen属性

下面的场景使用refs非常有用:

  • 对Dom元素的焦点控制内容选择,控制
  • 对Dom元素的内容设置媒体播放
  • 对Dom元素的操作和对组件实例的操作
  • 集成第三方Dom库
  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React Refs 是 React 提供的一种访问 DOM 元素或组件实例的方法。通过 Refs,我们可以在组件中直接访问到被 Refs 引用的 DOM 元素或组件实例,从而进行一些特殊的操作。 下面,我来举一个 React Refs 的案例: 假设我们有一个 Input 组件,需要在组件加载完毕后自动获取焦点,我们可以通过 Refs 来实现这个功能。具体的实现步骤如下: 1. 在 Input 组件中定义 Refs: ```jsx class Input extends React.Component { constructor(props) { super(props); this.inputRef = React.createRef(); // 创建 Refs } render() { return <input type="text" ref={this.inputRef} />; } } ``` 2. 在 componentDidMount 生命周期中,使用 Refs 获取到 input 元素,并调用 focus() 方法: ```jsx class Input extends React.Component { constructor(props) { super(props); this.inputRef = React.createRef(); // 创建 Refs } componentDidMount() { this.inputRef.current.focus(); // 获取 input 元素并获取焦点 } render() { return <input type="text" ref={this.inputRef} />; } } ``` 这样,当 Input 组件加载完毕后,它的 input 元素就会自动获取焦点了。 注意,Refs 只能在类组件中使用,不能在函数式组件中使用。另外,Refs 的值可以是回调函数,而不仅仅是 React.createRef() 方法返回的对象。如果使用回调函数的方式,可以在回调函数中访问到组件实例或 DOM 元素,例如: ```jsx class Input extends React.Component { constructor(props) { super(props); this.inputRef = null; // 创建 Refs this.setInputRef = element => { this.inputRef = element; }; } componentDidMount() { this.inputRef.focus(); // 获取 input 元素并获取焦点 } render() { return <input type="text" ref={this.setInputRef} />; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值