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 的效果。
相关推荐
我命由我123452 小时前
React - React Redux 数据共享、Redux DevTools、React Redux 最终优化
前端·javascript·react.js·前端框架·ecmascript·html5·js
英俊潇洒美少年2 小时前
数据驱动视图 vue和react对比
javascript·vue.js·react.js
Jinuss2 小时前
源码分析之React中的createContext/useContext详解
前端·javascript·react.js
AnalogElectronic2 小时前
uniapp学习7,美团闪购生鲜蔬菜商家详情页
javascript·学习·uni-app
琪伦的工具库2 小时前
在自动化部署流程中集成视频转GIF:工具选型与参数调优
javascript·自动化·音视频
永远的个初学者2 小时前
一个同时支持 React、Vue、Node、CLI、Vite、Webpack 的图片优化库:rv-image-optimize
vue.js·react.js·webpack
吃不胖爹2 小时前
Flutter 基本架构与使用
javascript·flutter·架构
哈__2 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-tts 语音播放
javascript·react native·react.js
Jinuss2 小时前
源码分析之React中useCallback和useMemo
前端·javascript·react.js