首页 / VUE / Vue 重置组件到初始状态的方法示例
Vue 重置组件到初始状态的方法示例
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Vue 重置组件到初始状态的方法示例,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1499字,纯文字阅读大概需要3分钟。
内容图文
![Vue 重置组件到初始状态的方法示例](/upload/InfoBanner/zyjiaocheng/335/35974a504ca644e0852064b0c620eb17.jpg)
Vue
通过直接强制刷新 DOM 来达到重置组件的效果,这样可以重置一些组件的动画以及组件内初始的数据
强制重新生成 DOM 的实现
原理:强制重新生成 DOM 可以通过 Vue 中的 key 来实现。在 Vue 更新 Dom 时,如果 key 值相同则会对原有组件进行复用,如果不同,则会重新生成。
代码示例:
每次点击 refresh 按钮,Demo 组件都会重新生成
组件:
/** * 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>
注:
对 +new Date() 的说明:
4 个结果一样,都是返回当前时间的毫秒数
alert(+new Date())
alert(+new Date)
var a=new Date()
alert(a.valueOf())
alert(a.getTime())
补充:vue强制刷新组件
把一个组件重置到初始状态是一个常见的需求,推荐的做法有两种,一种是父组件重置子组件的 prop,另一种是子组件暴露一个重置的方法供父组件调用。但有些时候,子组件既没有提供重置的方法,也没提供 prop 来重置自己的状态。更重要的是,这个子组件我们还动不了。于是我们就需要一种 hack 的方式来强制子组件重置到初始状态。方法如下:
<component v-if="hackReset"></component> this.hackReset = false this.$nextTick(() => { this.hackReset = true })
v-if 在切换时,元素及它的绑定数据和组件都会被销毁并重建
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
内容总结
以上是互联网集市为您收集整理的Vue 重置组件到初始状态的方法示例全部内容,希望文章能够帮你解决Vue 重置组件到初始状态的方法示例所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。