reactjs - React 中的单向数据流

标签 reactjs vue.js

React 具有单向数据流 的概念,与来自其他框架的双向数据绑定(bind) 形成对比,例如Vue.js

我制作了以下片段来感受本质区别,然后似乎 unidirectional 要求应用程序传播任何状态转换,而 two-way按照惯例为你做。

希望我可能误解了这里的要点,所以你能帮忙澄清一下二人组之间更根本的分歧吗?

var MyComponent = React.createClass({
  getInitialState: function () { 
    return {
      one: 'Hello', 
      two: 'world', 
      three: ''
    } 
  },
  handleValueOneChange: function (e) {
    this.setState({one: e.target.value})
  },
  handleValueTwoChange: function (e) {
    this.setState({two: e.target.value})
  },
  render: function () { 
    return (
      <div>
        <h1>
        {this.state.one + ' ' + this.state.two}
        </h1>
        <input value={this.state.one} 
          onChange={this.handleValueOneChange} />
        <input value={this.state.two} 
          onChange={this.handleValueTwoChange} />
      </div>
    )   
  }
})

ReactDOM.render(
  <MyComponent />, document.getElementById('app')
)
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>

<div id="app"/>

new Vue({
  el: '#app', 
  data: {
    one: 'Hello',
    two: 'world'
  },
  computed: {
    three: function() { return this.one + ' ' + this.two }
  }
})
<script src="https://npmcdn.com/vue/dist/vue.js"></script>
<div id="app">
  <h1>{{ three }}</h1>
  <input v-model="one" />
  <input v-model="two" />
</div>

最佳答案

没错。我不熟悉 vue.js,但 angular 也做了类似于双向数据绑定(bind)的事情。现在,当你需要 React 时,它可能看起来太乏味了,因为你需要编写所有额外的代码(至少感觉是这样)。

但我注意到,大多数页面和您编写的大多数 html 组件都不需要双向数据绑定(bind)。它们对于基于表单的元素是必不可少的,仅此而已。而且大多数页面都不是基于表单的。我认为 Angular 团队已经意识到这一事实以及它对应用程序性能的影响程度,因此他们从 1.3 版开始引入了单向数据绑定(bind)的结构。

因此,总的来说,这取决于您要尝试做什么并选择最佳解决方案。例如,您可能正在编写一个完全基于表单的应用程序(我以这种方式编写了一个拥抱应用程序),双向数据绑定(bind)将提供巨大的帮助。但大多数其他人,单向就足够了。

以下是您可能感兴趣的其他 SO 帖子:

Can anyone explain the difference between Reacts one-way data binding and Angular's two-way data binding

What is two way binding?

关于reactjs - React 中的单向数据流,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38948503/

相关文章:

vue.js - 使用 BootstrapVue 以编程方式编写导航链接的正确方法

javascript - Buefy 工具提示中的新行

javascript - Vue js组件在没有页面刷新的情况下不渲染数据

javascript - 尝试从 NodeJS 后端的 API 获取数据时出现请求过多错误,但适用于 React 前端

reactjs - 服务器端渲染如何与单页应用程序兼容?

reactjs - React mui-datatable 分页从 0 开始,而不是 1

javascript - mac(本地主机)上的 vue-router 历史模式在直接访问时抛出错误

javascript - 为什么 Dispatcher 在 Flux 上发起不必要的事件?

ios - 似乎您正在尝试从 'ReactNative.Component' 包访问 'react-native'

vue.js - 在 Quasar CLI 中使用 lang ="pug"