首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用.sync呈现函数在javascript中编写vue .sync

如何使用.sync呈现函数在javascript中编写vue .sync
EN

Stack Overflow用户
提问于 2018-04-26 11:36:26
回答 2查看 4.3K关注 0票数 4

我将代码从模板文件更改为呈现函数。现在我有了这个HTML:

代码语言:javascript
运行
复制
:open.sync="state"

但我不知道如何把这个翻译成JavaScript。如何将其写入createElement函数?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-04-26 13:28:43

记住这一点

代码语言:javascript
运行
复制
:open.sync="state"

的语法糖

代码语言:javascript
运行
复制
:open="state" @update:open="state = $event"

那么,呈现函数中的等效内容将是:

代码语言:javascript
运行
复制
createElement('child', {
  props: {                                   // :open="state"
    "open": this.state
  },
  on: {                                      // @update:open="state = $event"
    "update:open": ($event) => {
      this.state = $event;
    }
  }
})

演示:

代码语言:javascript
运行
复制
Vue.component('child', {
  template: '#child',
  props: ['open']
})

new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue.js!'
  },
  render(createElement) {
    return (
      createElement('div', [
        this.message,
        createElement('br'),
        createElement('child', {
          props: {
            "open": this.message
          },
          on: {
            "update:open": ($event) => {
              this.message = $event;
            }
          }
        })
      ])
    );
  }
})
代码语言:javascript
运行
复制
<script src="https://unpkg.com/vue"></script>

<div id="app">
  <p>{{ message }}</p>
  <child :open.sync="message"></child>
</div>

<template id="child">
  <div>
    <input type="text" :value="open" @input="$emit('update:open', $event.target.value)">
    open: {{ open }}
  </div>
</template>

票数 14
EN

Stack Overflow用户

发布于 2021-03-17 10:05:33

作为2021年3月&来自@acdc初级灵感公司,我想出了一个解决方案:

代码语言:javascript
运行
复制
// From Parent 
<custom-input
  :open.sync="formData.groupName"
/>
代码语言:javascript
运行
复制
// CHILD
<div class="wrapper">
      <input
        type="text"
        class="full-width"
        :value="open" @input="$emit('update:open', $event)"
      />
</div>

顺便说一句:他的解决方案不起作用,因为$event.target.value是没有定义的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50041991

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档