[英]Knockout computed observable with access to observableArray
我在使用computedObservable
遇到了问题。 他们看起来很直接,但我认为我的用例可能有点奇怪。 问题是当onBottom()
时,它不会看到container.slides()
数组中的项。 相反,我得到“未定义不是一个功能”。
由于onTop()
工作正常,它让我认为它是导致问题的Slide
和FeaturedContent
之间的关系,但我认为它应该工作正常。 这里的任何帮助将不胜感激。
HTML
<div class="section-block" data-bind="foreach: slides">
<div class="row well">
<div class='control'>
<a href='#' data-bind="click: moveUp, ifnot: onTop">
<i class="fa fa-arrow-up"></i>
</a>
<a href='#' data-bind="click: moveDown, ifnot: onBottom">
<i class="fa fa-arrow-down"></i>
</a>
<span class='pull-right'>Remove</span>
</div>
<h5 data-bind="text: headline"></h5>
<p data-bind="text: image"></p>
</div>
</div>
JS
var FeaturedContent = function() {
var self = this;
self.maxSlides = 14;
self.slides = ko.observableArray([
new Slide({}, "I should be last", "someimg", 0, self),
new Slide({}, "I should be first", "anotherimg", 1, self),
new Slide({}, "I should be second-", "anotherimg", 2, self),
]);
// ... snipped.
};
var Slide = function(contentItem, headline, image, order, container) {
var self = this;
// -- Data
self.contentItem = contentItem;
self.headline = headline;
self.image = image;
self.position = ko.observable(0);
self.onBottom = ko.computed(function() {
return (self.position() === container.slides().length - 1) ? true : false;
});
self.onTop = ko.computed(function() {
return (self.position() === 0) ? true : false;
});
return self;
};
在创建过程中
self.slides = ko.observableArray([
new Slide({}, "I should be last", "someimg", 0, self),
new Slide({}, "I should be first", "anotherimg", 1, self),
new Slide({}, "I should be second-", "anotherimg", 2, self),
]);
在FeaturedContent
您的代码将创建new Slide
并使用self
来获取container.slides().length
即self
是container
但slides()
尚未创建。 这是一个圆圈参考。 所以container.slides()
是未定义的。
尝试像这样的container.slides() && self.position() === container.slides().length - 1
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.