Я следую этому руководству по созданию блога с помощью node.js, express и mongodb.
Ниже приведены функции, управляющие подачей статей (я думаю).
провайдеров и данных
Потому что цель этой статьи - показать, как можно использовать
Постоянный подход в node.js начнем с абстракции:
поставщик. Эти «провайдеры» будут нести ответственность за возвращение и
обновление данных. Изначально мы создадим фиктивную версию в памяти
просто чтобы запустить нас в работу, но затем мы перейдем к использованию
реальный уровень персистентности без изменения вызывающего кода.
articleprovider-memory.js:
var articleCounter = 1;
ArticleProvider = function(){};
ArticleProvider.prototype.dummyData = [];
ArticleProvider.prototype.findAll = function(callback) {
callback( null, this.dummyData )
};
ArticleProvider.prototype.findById = function(id, callback) {
var result = null;
for(var i =0;i<this.dummyData.length;i++) {
if( this.dummyData[i]._id == id ) {
result = this.dummyData[i];
break;
}
}
callback(null, result);
};
ArticleProvider.prototype.save = function(articles, callback) {
var article = null;
if( typeof(articles.length)=="undefined")
articles = [articles];
for( var i =0;i< articles.length;i++ ) {
article = articles[i];
article._id = articleCounter++;
article.created_at = new Date();
if( article.comments === undefined )
article.comments = [];
for(var j =0;j< article.comments.length; j++) {
article.comments[j].created_at = new Date();
}
Может ли кто-нибудь объяснить мне простым языком, что делает каждая функция (извините, я новичок в JavaScript)?
(кстати, именно из-за какой-либо общепринятой практики автор решил начать с CAP только в ArticleProvider
?)