2016-06-26 8 views
0

Я создал новый объект с именем Project, который содержит галерею и некоторые другие поля в ней. В представлении я показываю некоторые данные, и я хочу поместить ссылку на предыдущий и следующий проект. Мне уже удалось получить предыдущий проект, но когда я пытаюсь извлечь из него слизь, как-то это не сработает.Получить slug из объекта в поле зрения не будет

Это модель проекта:

var keystone = require('keystone'); 
var Types = keystone.Field.Types; 

/** 
* Project Model 
* ========== 
*/ 

var Project = new keystone.List('Project', { 
    map: { name: 'title' }, 
    autokey: { path: 'slug', from: 'title', unique: true } 
}); 

Project.add({ 
    title: { type: String, required: true }, 
    state: { type: Types.Select, options: 'draft, published, archived', default: 'draft', index: true }, 
    author: { type: Types.Relationship, ref: 'User', index: true }, 
    publishedDate: { type: Types.Date, index: true, dependsOn: { state: 'published' } }, 
    category: { type: String, required: false }, 
    description: { type: Types.Html, wysiwyg: true, height: 150 }, 
    shortDescription: { type: Types.Html, wysiwyg: true, height: 100 }, 
    credits: { type: Types.Html, wysiwyg: true, height: 100 }, 
    galleries: { type: Types.Relationship, ref: 'Gallery', many: false }, 
    color: { type: String, required: false } 
}); 

Project.schema.virtual('content.full').get(function() { 
    return this.content.extended || this.content.brief; 
}); 

Project.defaultColumns = 'title, state|20%, author|20%, publishedDate|20%'; 
Project.register(); 

Это контроллер:

var keystone = require('keystone'); 

exports = module.exports = function(req, res) { 

    var view = new keystone.View(req, res); 
    var locals = res.locals; 

    // Set locals 
    locals.section = 'projects'; 
    locals.filters = { 
     project: req.params.project 
    }; 
    locals.data = { 
     projects: [], 
     previousProject: [] 
    }; 

    // Load the current project 
    view.on('init', function(next) { 

     var q = keystone.list('Project').model.findOne({ 
      state: 'published', 
      slug: locals.filters.project 
     }).populate('galleries'); 

     q.exec(function(err, result) { 
      locals.data.project = result; 
      next(err); 
     }); 

    }); 

    //Load other projects 
    view.on('init', function(next) { 

     var q = keystone.list('Project').model.find({state: "published", publishedDate: {$lt: locals.data.project.publishedDate}}).sort('-publishedDate').limit(1); 
     q.exec(function(err, results) { 
      locals.data.previousProject = results; 
      next(err); 
     }); 

    }); 

    // Render the view 
    view.render('project'); 

}; 

И это мнение:

<div class="container"> 
    <p>{{{data.project.title}}}</p> 
    <p>—</p> 
    <p>{{{data.project.category}}}</p> 

    {{#if data.project.galleries}} 
     {{#each data.project.galleries.images}} 
      <img src="{{url}}" /> 
     {{/each}} 
    {{/if}} 
    <p>full project: {{data.previousProject}}</p> 
    <p>slug: {{data.previousProject.slug}}</p> 
    {{#if data.previousProject}} 
     <a href="/projects/{{data.previousProject.slug}}" >Previous project</a> 
    {{/if}} 
</div> 

Каким-то образом, {{data.previousProject}} показывает правильное инфо-запись но когда я делаю {{data.previousProject.slug}}, он ничего не возвращает. Я несколько часов царапаю голову против этого, но я не могу найти, где проблема. Заранее спасибо!!

ответ

0

я, наконец, нашел то, что этот вопрос: в контроллере я использую model.find тогда я должен использовать model.findOne, если я знаю, что нужно только одну запись, и я хочу, чтобы непосредственно получить значения из него с .slug. Использовать limit(1) было недостаточно.