繁体   English   中英

Vue.js 3.0 - 使用 Composition API 的双向数据绑定

[英]Vue.js 3.0 - Two-Way Data Binding with Composition API

我正在使用 Vue.js 3.0 编写一个 Vue.js 应用程序。 我使用它作为学习 Composition API 的一种方式。 我喜欢 Vue.js 2.0 的特性之一是双向数据绑定的易用性。 但是,对于 Composition API,我不清楚如何使用它。 特别是当使用全局状态时。 例如,我的应用程序有两个组件,如此 Fiddle所示。 代码如下所示:

HTML

<div id="my-vue" class="demo">
  <banner :class="{ 'even-banner': isEven, 'odd-banner': !isEven }"></banner>
  <hr />
  <content :class="{ 'even-content': isEven, 'odd-content': !isEven }"></content>
  <pre>value={{value}} isEven={{isEven}}</pre>
</div>

JavaScript

const store = {
  state: Vue.reactive({
    result: null
  }),
  generateNewValue() {
    this.state.result = Math.floor(Math.random() * 10);
  }
};

const MyApp = {
  setup() {
    const isEven = Vue.computed(() => store.state.result % 2 === 0)
    const value = Vue.toRef(store.state, 'result')
    return {
      isEven,
      value
    }
  }
}
const myApp = Vue.createApp(MyApp)

myApp.component("banner", 
  { 
    template: '<button @click="onGenerateClick">generate</button>',
    setup(props) {
      console.log('setting up...');
    },
    methods: {
      onGenerateClick() {
        store.generateNewValue();
      }
    }
  }
);

myApp.component("content", {
  template: '<div style="padding:2rem;">' +
    '<div>Enter Value: <input type="text" v-model="result" /></div>' +
    '<br /><div>or</div><br />' +
    '<div><button @click="onGenerateClick">generate</button></div>' +
    '</div>',
  methods: {
    onGenerateClick() {
      store.generateNewValue();
    }
  }  
});

myApp.mount('#my-vue')

CSS

.even-banner {
  background-color:navy;
  color: #fff;
}

.even-content {
  background-color:blue;
  color: #fff;
}

.odd-banner {
  background-color:maroon;
  color:#fff;
}

.odd-content {
  background-color:red;
  color:#fff;
} 

这个想法很简单:如果一个数字是偶数,使用蓝色背景。 如果数字是奇数,请使用红色背景。 我有一个按需要工作的生成按钮。 但是,这个小应用程序有一个文本字段,您可以在其中手动输入一个值。该值当前不会根据需要更改背景。 这就像双向绑定不起作用。

在使用 Composition API 的 Vue.js 应用程序中,如何让双向数据绑定与全局状态一起工作?

您的文本输入没有绑定到存储值,它只是引用了一个不存在的名为 result 的数据属性。 尝试将 store 注入到组件中,然后将 getter/setter 添加到绑定属性

myApp.component("content", {
store,
  template: '<div style="padding:2rem;">' +
    '<div>Enter Value: <input type="text" v-model="myAmount" /></div>' +
    '<br /><div>or</div><br />' +
    '<div><button @click="onGenerateClick">generate</button></div>' +
    '</div>',
    computed:{
        myAmount:{
      get: function(){return store.state.result},
      set: function(val){store.state.result = val}
      }
    },
  methods: {
    onGenerateClick() {
      store.generateNewValue();
    }
  }  
});

顺便说一句,我的 setter 是一个快速的 hack,你通常不会直接更新 store.state 属性,但它应该让你开始

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM