美文网首页vuereact & vue & angular散文
react中的v-model双向绑定

react中的v-model双向绑定

作者: 绿芽 | 来源:发表于2022-09-22 10:20 被阅读0次

    前言:因为项目原因需要学习另一个超级火的框架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 (
          <div>
            <form onSubmit={handleSubmit}>
            </form>
          </div>
        )
      }
    }
    

    而在函数式组件中,使用hooks可以将这个统一的state值根据功能和场景拆分为多个state用来更加方便的使用和维护,如:

    import React, { useState } from 'react'
    export default function ModelChange() {
      const [name, setName] = useState('')
      const [age, setAge] = useState()
      const handleSubmit = () => {
      }
      return (
        <div>
          <form onSubmit={handleSubmit}>
          </form>
        </div>
      )
    }
    

    需要注意的是,如果需要改变维护的状态的值,需要使用指定的方法才会使页面更新,如函数式组件中定义的setName方法等。下面就看看react在input输入框中实现双向绑定,代码如下:

    import React, { useState } from 'react'
    
    export default function ModelChange() {
      const [name, setName] = useState('')
      const handleCnhange = e => {
        const data = e.target.value
        setName(data)
      }
      return (
        <div>
          <form>
            <label>
              名字:
              <input type="text" value={name} onChange={handleCnhange} />
            </label>
          </form>
        </div>
      )
    }
    

    上面的代码通过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.target
        setData(preData => {
          return {
            ...preData,
            [name]: value
          }
        })
      }
      const handleSubmit = (e) => {
        console.log(data)
      }
      return (
        <div>
          <form>
            <label>
              名字:
              <input type="text" name="name" value={data.name} onChange={handleCnhange} />
            </label>
            <label>
              年龄:
              <input type="text" name="age" value={data.age} onChange={handleCnhange} />
            </label>
            <input type="button" value="提交" onClick={handleSubmit} />
          </form>
        </div>
      )
    }
    

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

    相关文章

      网友评论

        本文标题:react中的v-model双向绑定

        本文链接:https://www.haomeiwen.com/subject/qbdiortx.html