作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我查看下面的距离计算属性时,返回的数据是常量,而不是仅在数据更改时返回。
这是因为我正在设置然后观看而发生的,还是有错误?我想在用户更改计算属性时观察并重新格式化一些输出数据。
computed: {
distance: {
get: function() {
let location = parseFloat(this.radius_search.lat) + ', ' + parseFloat(this.radius_search.lng);
return this.search_store.queryParameters = { aroundLatLng: location, aroundRadius: this.radiusToMetres };
},
set(value) {
return this.search_store.queryParameters = this.distance;
},
},
radiusToMetres(){
return this.radius * 1600;
},
},
watch: {
distance: function(value) {
console.log(value);
},
},
下面是控制台输出的屏幕截图。
最佳答案
您在 getter 中分配一个值,这是一种不好的做法。 setter/getter 应该没有副作用。
特别是,您正在创建一个新对象并将其分配给返回值,这会导致循环:distance
每次查看时都会获取一个新值一个新值,它的依赖项(比如你的观察者)正在查看它。
关于javascript - 观察 Vue.js 计算属性在控制台中返回循环数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49567016/
我是一名优秀的程序员,十分优秀!