react中的双向绑定你真的了解吗

前言:因为项目原因需要学习另一个超级火的框架react, 因为之前一直使用vue进行开发,所以在学习react中会不自觉的代入一些vue中的概念来理解react中的实现,下面就通过对比学习的方式记录下react中的知识。
在react中其实是没有双向绑定的概念,每次更新页面和值都需要我们自己去调用指定的api来触发,而在vue中只需要使用v-model指令就可以完全实现,在vue中的指令其实也是使用了几个事件的语法糖来实现,所以下面就去看下react中的“双向绑定”是怎么来实现的。
如果实现react中得双向绑定,首先要理解state这个属性,简单来说react中得state就是一个对象,它用来缓存和维护当前组件中所使用到得状态,可以理解为vue中data中定义得值,如:

import React, { Component } from 'react'export default class Class extends Component {constructor(props) {super(props)this.state = {name: '', age: ''}}render() {return (
)}}

【react中的双向绑定你真的了解吗】而在函数式组件中,使用hooks可以将这个统一的state值根据功能和场景拆分为多个state用来更加方便的使用和维护,如:
import React, { useState } from 'react'export default function ModelChange() {const [name, setName] = useState('')const [age, setAge] = useState()const handleSubmit = () => {}return (
)}

需要注意的是,如果需要改变维护的状态的值,需要使用指定的方法才会使页面更新,如函数式组件中定义的setName方法等。下面就看看react在input输入框中实现双向绑定,代码如下:
import React, { useState } from 'react'export default function ModelChange() {const [name, setName] = useState('')const handleCnhange = e => {const data = https://www.it610.com/article/e.target.valuesetName(data)}return (
)}

上面的代码通过useState定义了值name,然后通过input标签的value将name展示出来,通过监听change事件获取输入的值并调用定义好的方法setName修改name的值并更新页面,又使页面展示为新输入的值,通过这个流程的操作就实现了在react中的双向绑定。如果我们想要修改和获取多个输入的值可以使用name属性来实现,代码如下:
import React, { useState } from 'react'export default function ModelChange() {const [data, setData] = useState({name: '', age: ''})const handleCnhange = e => {const {value, name} = e.targetsetData(preData => {return {...preData,[name]: value}})}const handleSubmit = (e) => {console.log(data)}return (
)}

上面代码将name和age字段声明在了一个集合中(根据业务和使用场景也可以进行拆分定义),通过给input标签添加name属性来更给指定属性更新当前输入的值,效果如下:
react中的双向绑定你真的了解吗
文章图片

总结 本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

    推荐阅读