微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vue.js - 未计算组件高度和宽度

如何解决Vue.js - 未计算组件高度和宽度

我的组件中有以下代码

computed: {
    gridWidth()  { return (this.$el && this.$el.offsetWidth)  },gridHeight() { return (this.$el && this.$el.offsetHeight) },},mounted(){
    console.log(this.$el && this.$el.offsetWidth,this.gridWidth,this.$el && this.$el.offsetHeight,this.gridHeight)
},

控制台输出为:

1766 undefined 931 undefined

为什么计算属性未定义?

会以正确的方式成为观察者吗?为什么以及如何实现?

解决方法

这基本上与 reactivity in Vue 的工作原理有关。默认情况下,您的 DOM 不会持续提供更新的值。

您可以使用 vm.$nextTickvm.$watch 在渲染完成后基本上附加一个观察者,或者您可以使用一个小型库来满足您的需求:>

vue-resize-directive

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。