react如何实现双向绑定

React 本身没有内置双向绑定 ,它默认是单向数据流
state → 视图

视图要改回 state,必须手动写事件监听

所谓 React 的双向绑定,就是自己把"数据到视图"+"视图到数据"封装起来

一、最简实现(原生 React)

jsx 复制代码
function App() {
  const [value, setValue] = useState('')

  return (
    <input
      value={value}
      onChange={(e) => setValue(e.target.value)}
    />
  )
}

这就是 React 版双向绑定

  • 数据 → 视图:value={value}
  • 视图 → 数据:onChangesetValue

二、封装成类似 v-model 的工具

你可以封装一个自定义 Hook,实现像 Vue 一样简洁:

jsx 复制代码
function useModel(initialState) {
  const [value, setValue] = useState(initialState)
  return {
    value,
    onChange: e => setValue(e.target.value)
  }
}

// 使用
function App() {
  const username = useModel('')

  return <input {...username} />
}

这样就和 v-model="username" 几乎一样用。

三、React 18 官方:useImperativeHandle 不算

真正 React 里:

  • 没有 v-model 指令
  • 没有自动双向绑定
  • 一切都是**受控组件(Controlled Component)**手动实现

四、和 Vue 对比

Vue React
双向绑定 v-model 内置指令 无内置,手动 value + onChange
数据流 天然双向 单向数据流,手动实现双向
简洁度 极简洁 稍繁琐,但更可控

五、面试标准答案

  1. React 没有内置双向绑定 ,遵循单向数据流
  2. 通过受控组件 实现双向绑定:
    • value 绑定 state
    • onChange 事件更新 state
  3. 可以封装自定义 Hook 简化写法,达到类似 v-model 的效果。
相关推荐
游九尘11 小时前
JavaScript 实现三段式版本号对比函数(app升级用)
javascript·uni-app
zhiSiBuYu051711 小时前
Claude-Code 新手极速上手指南
javascript·node.js
罗超驿12 小时前
18.Web API 实战:元素与表单属性的获取和修改
开发语言·前端·javascript
山河已无恙13 小时前
BPF-eBPF 开发路线二:libbpf、CO-RE 与 libbpf-bootstrap认知
javascript·bootstrap·php
ZengLiangYi13 小时前
React Query + REST API 最佳实践
javascript·后端·react.js
ZengLiangYi13 小时前
Fastify 加 Electron:把 Web 服务嵌进桌面应用
前端·javascript·后端
胡萝卜术14 小时前
从零搭建生成式AI项目:OpenAI + Node.js 环境配置与密钥安全实践
前端·javascript·面试
柒和远方14 小时前
每日一学V012: 从 Python 到 Node.js:一个 AI Native 开发者的 JavaScript 调用 LLM 实战
javascript·node.js·api
STDD14 小时前
Farming Simulator 25(模拟农场 25) Linux 专服搭建完全指南
linux·运维·javascript
超人气王15 小时前
新手学前端 JavaScript 类型判断:一篇彻底搞懂 typeof、instanceof 和 Object.prototype.toString
前端·javascript