我试图制作单页应用程序(使用Knockout.js - 它是必要的),它在网上商店模仿产品页面。以下是它的外观(为了更好地理解):
我使用require.js,knockout.js和underscore.js按价格过滤项目。问题是 - 有时我会得到_.filter不是函数的错误。这是我的补充工具栏ViewModel文件:
define(
['jquery', 'underscore', 'knockout', 'core/get_product_list', 'core/read_set_data', 'text!view-model/sidebar/sidebar.tmpl'],
function ($, _, ko, getProductList, ReadSetData, sidebarTemplate) {
var SidebarViewModel = function (options) {
//Variables
var self = this;
self.sidebarElement = options.sidebarElement;
self.currentProductsPerPage = ReadSetData.currentProductsPerPage;
self.pageNumber = ReadSetData.pageNumber;
self.items = ReadSetData.items();
self.itemsTotal = ko.computed(function () {
return self.items.length;
});
self.filterPrice = ko.observableArray();
//Applying template
self.sidebarElement.html(sidebarTemplate);
//Filtering by price using Underscore
self.applyPriceFilter = ko.computed(function(){
if (self.filterPrice().length !== 0) {
var minValue, maxValue;
$.each(self.filterPrice(), function() {
var min = Number(this.split('-')[0]),
max = Number(this.split('-')[1]);
if (!minValue && !maxValue) {
minValue = min;
maxValue = max;
}
if (minValue > min) minValue = min;
if (maxValue < max) maxValue = max;
});
var filterItems = _.filter(self.items, function(item) {
return (item.price() > minValue && item.price() < maxValue);
});
ReadSetData.pageNumber(0);
ReadSetData.items(filterItems);
}
else
{
ReadSetData.pageNumber(0);
ReadSetData.items(self.items);
}
});
};
return SidebarViewModel;
});
按价格按预期过滤,但如果我刷新页面几次 - 即时收到此错误:
如果我再次刷新页面,此错误消失并再次过滤正常工作。看起来像underscore.js没有加载,这是错误的原因(我认为)。
这是我的require.config:
require.config({
paths: {
text: '../libs/text/text',
jquery: '../libs/jquery/jquery-min',
popper: '../libs/popper/popper-min',
underscore: '../libs/underscore/underscore',
knockout: '../libs/knockout/knockout',
bootstrap: '../libs/bootstrap-grid/bootstrap',
material_design: '../libs/material-design/mdb'
},
shim: {
jquery: {
exports: '$'
},
underscore: {
exports: '_'
},
material_design: {
deps: ['jquery']
}
}
});
require(['jquery', 'popper', 'bootstrap', 'knockout', 'material_design', 'main'], function(
$,
popper,
bootstrap,
ko,
Material_design,
MainViewModel
) {
var mainContent = $('#main'); //keep a reference to the root element
// ---------------------------------------------
// Applying bind of the MainViewModel
// ---------------------------------------------
ko.applyBindings(
new MainViewModel({
element: mainContent
}),
mainContent[0]
);
});
我做错了什么?也许我写错了顺序?或者任何想法可能是错的?谢谢!