第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定

對 vue 修飾符 .sync 的理解

標(biāo)簽:
Html5 CSS3 Sass/Less

其实对这个属性有点陌生,一直都好像没怎么用到这个属性,但是就在今天,因为公司现在重构的这个项目是拿着element-ui的组件库改造的组件,变成公司自己的组件,所以当我在使用某一些组件的时候,好像是在使用 模态框的时候,我看到的这个属性,特别的好奇,
在这里插入图片描述
在使用的时候确实这样使用的
在这里插入图片描述
其实看官网就比较清楚了
在这里插入图片描述
在这里插入图片描述
在说vue 修饰符sync前,我们先看下官方文档:vue .sync 修饰符,里面说vue .sync 修饰符以前存在于vue1.0版本里,但是在在 2.0 中移除了 .sync 。但是在 2.0 发布之后的实际应用中,我们发现 .sync 还是有其适用之处,比如在开发可复用的组件库时。我们需要做的只是让子组件改变父组件状态的代码更容易被区分。从 2.3.0 起我们重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 监听器。

<comp :foo.sync="bar"></comp>

会被扩展为:

<comp :foo="bar" @update:foo="val => bar = val"></comp>

当子组件需要更新 foo 的值时,它需要显式地触发一个更新事件:

this.$emit('update:foo', newValue)

我们可以写一个MyComponent.vue子组件

<template>
<div v-if="show">
  <p>默认初始值是{{show}},所以是显示的</p>
  <button @click.stop="closeDiv">关闭</button>
</div>
</template>

<script>
export default {
  name: "myComponent",
  props: ['show'],
  methods: {
      closeDiv() {
        this.$emit("update:show", false)
      }
    }
}
</script>

再编写一个父组件 Synca.vue

<template>
  <div class="details">
    <myComponent :show.sync="valueChild" style="padding: 30px 20px 30px 5px;border:1px solid #ddd;margin-bottom: 10px;"></myComponent>
    <button @click="changeValue">toggle</button>
  </div>
</template>
<script>
import myComponent from "../components/MyComponent"
export default {
  components: {
    myComponent
  },
  data() {
    return {
      valueChild: true
    }
  },
  methods: {
    changeValue() {
      this.valueChild = !this.valueChild
    }
  }
}
</script>

在这里插入图片描述
vue 修饰符sync的功能是:当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定。如果我们不用.sync,我们想做上面的那个弹窗功能,我们也可以props传初始值,然后事件监听,实现起来也不算复杂。这里用sync实现,只是给大家提供一个思路,让其明白他的实现原理,可能有其它复杂的功能适用sync。

作者:littleTank
链接:https://www.jianshu.com/p/6b062af8cf01
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評論

作者其他優(yōu)質(zhì)文章

正在加載中
Web前端工程師
手記
粉絲
23
獲贊與收藏
130

關(guān)注作者,訂閱最新文章

閱讀免費(fèi)教程

  • 推薦
  • 評論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評論
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊有機(jī)會得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號

舉報(bào)

0/150
提交
取消