Vue杂记之强制重新生成DOM

对于一个vue组件,如果我们想要吧它重置到最初始的状态,一般只需要将组件内部的数据进行重置即可。但是在某些情况下,这种方法并不适用。比如

  • 组件在初始化时并不会触发watch选项中的函数,而将数据进行重置时则会触发。如果我们想要将数据进行重置却不想执行watch中的函数则会考虑重新生成DOM。
  • 如果我们直接对DOM进行了修改而不是通过修改数据更新DOM。
  • 如果我们使用了CSS中的transition属性实现过度动画。比如已经完成了opacity:0opacity:1的过度效果。现在想将CSS重置为opacity:0却不想出现动画效果。

强制重新生成DOM的实现

强制重新生成DOM可以通过vue中key来实现。在vue更新DOM时,如果key值相同则会对原有组件进行复用,如果不同,则会重新生成。

代码示例:

/**
 * Demo.vue
 */
<template>
  <div>Demo</div>
</template>
<script>
  export default {
    data () {
      return {}
    },
    created: function () {
      console.log('created')
    }
  }
</script>
/**
 * Index.vue
 */
<template>
  <div>
  <Demo :key="id"></Demo>
  <button @click="$refresh">refresh</button>
  </div>
</template>
<script>
  import Demo from './Demo'
  export default {
    data () {
      return {
        id: +new Date()
      }
    },
    methods: {
      $refresh: function () {
        this.id = +new Date()
      }
    },
    components: {
      Demo
    }
  }
</script>

每次点击refresh按钮,Demo组件都会重新生成

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,178评论 0 29
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,299评论 4 129
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,373评论 0 6
  • explode() 把字符串按照匹配的分割字符,分割成数组返回; 基础语法:array explode(strin...
    彭晓华阅读 839评论 0 0
  • 今天开始穿一个公司短袖上上班了,中午我值班,没有时间去看书,只是闲着坐在店内,翻动着手机,时间流逝很快,没有好像的...
    目瞪口袋阅读 138评论 0 0

友情链接更多精彩内容