我正在使用 jQuery Mobile/Knockout.js/iScrollView 构建一个 Web 应用程序。我有一个使用 Knockout.js foreach 填写的列表。我发出一个 ajax 请求,我得到一个 JSON 对象,我将它推送到我的 observable 数组中,并且我的页面通过向我显示我需要的所有内容来更新。
现在我想使用 iScrollView 以便随着列表的增长,我可以顺利向下滚动并利用上拉或下拉功能。
我似乎无法弄清楚在$(element).iscrollview('refresh')
正确的时间调用的正确方法,以便在添加更多项目后调整滚动窗口的大小。
有没有办法等到所有项目都插入到 DOM 中然后调用$(element).iscrollview('refresh')
.
这是我的 HTML
<div data-role="page" id="List" data-bind="event: {pageshow: loadItems}">
<div data-role="content" data-iscroll>
<button value='load' data-bind="event: {click: loadItems}">load more stuff</button>
<ul data-role="none" class="list" data-bind="foreach: items">
<li style="visibility:hidden">
<div class="header">
<h3 data-bind="text: name"></h3>
<p></p>
</div>
<div class="feat-list-btn feat-list-action">
<img src="image.png" />
</div>
<div class="feat-list-btn feat-list-comments">
<img src="image.png" />
</div>
<img data-bind="attr: {src: imageurl}" />
</li>
</ul>
</div>
</div>
这是我获取内容的方式:
function List(){
var self = this;
self.loadItems = function(){
$('#List [data-role="content"]').fadeOut(0);
$.mobile.showPageLoadingMsg();
jQuery.ajax({
url: mybackend.php',
type: 'POST',
data: 'howMany=10',
dataType: 'jsonp',
jsonp: 'jsoncallback',
success: function(data, textStatus, jqXHR){
for (i=0;i<data.items.length;i++){
self.items.push(data.items[i]);
}
},
complete: function(){
$.mobile.hidePageLoadingMsg();
}
});
};
self.items = ko.observableArray();
self.updateScroller = function(){
//????????
};
}
我可以通过这样做来解决这个问题
setTimeout(function(){$('#List [data-role="content"]').iscrollview('refresh');}, 1000);
但我宁愿不依赖 setTimeOut 来完成这样的事情。