React中的单向数据流

时间:2016-08-15 02:22:00

标签: reactjs vue.js

React的概念为unidirectional data flow,与其他框架中的two-way data binding形成鲜明对比,例如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>

2 个答案:

答案 0 :(得分:6)

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

但我注意到大多数页面和你编写的大多数html组件都不需要双向数据绑定。它们对于基于表单的元素至关重要,而且主要是它。而且大多数页面都不是基于表单的。我认为角度团队已经意识到这个事实以及它对应用程序性能的影响程度,因此他们引入了从1.3版本开始的单向数据绑定的构造。

因此,总的来说,这取决于您要做的事情并选择最佳解决方案。例如,你可能正在编写一个完全基于表单的应用程序(我用这种方式编写了一个拥抱应用程序),双向数据绑定将是非常有用的。但大多数其他人,单向足够好。

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

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

What is two way binding?

答案 1 :(得分:0)

这篇文章有一些误解。

  

虽然有点神奇,但v-model基本上是语法糖   更新用户输入事件的数据,以及对某些边缘的特殊照顾   案例。 https://vuejs.org/v2/guide/forms.html

Vue.js&#39; s v-model="one"是(不完全是一种)

的快捷方式
v-bind:value="one" v-on:change="one = $event.target.value."

逻辑与它在React

中完成的方式相同
value={this.state.one} onChange={this.handleValueOneChange}

这是同样的事情。只是你需要在React中编写更多的样板/重复代码。