gpt4 book ai didi

node.js - 在 Keystone.js 中显示带有描述的图库图像时出现问题

转载 作者:太空宇宙 更新时间:2023-11-04 00:35:59 25 4
gpt4 key购买 nike

我是 Keystone.js 和 Mongodb/nodejs 开发的新手,但我已经喜欢它了。

我正在尝试更改 Keystone 中的默认图库行为,以便为图库中的每个图像添加名称和描述,因为“Types.CloudinaryImages”似乎不允许这样做。可在 Image gallery with caption using CloudinaryImage on keystonejs 上找到我添加了一个新的“图像”模型并修改了我的主页(应显示图库的位置)的路线。

检查控制台日志时,查询确实会检索图库并填充图像的链接,但我的代码显示它们时出现问题。

图库模型

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

/**
* Gallery Model
* =============
*/

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

Gallery.add({
name: { type: String, required: true },
published: {type: Types.Select, options: 'Yes, No', default: 'No', index: true, emptyOption: false},
publishedDate: { type: Date, index: true, dependsOn: {published: 'Yes'} },
heroImage: { type: Types.Relationship, ref:'Image' },
images: { type: Types.Relationship, ref: 'Image', many: true },
});


Gallery.track = true;
Gallery.defaultColumns = 'title, published|20%, publishedDate|20%';
Gallery.register();

图像模型

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


/**
* Image Model
* =============
*/

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

Image.add({
name: { type: String, required: true },
publishedDate: { type: Date, default: Date.now },
image: { type: Types.CloudinaryImage, autoCleanup: true, required: true, initial: false },
description: { type: Types.Textarea, height: 150 },
});

Image.relationship({ ref: 'Gallery', path: 'heroImage' });
Image.relationship({ ref: 'Gallery', path: 'images' });

Image.register();

路由:index.js

var keystone = require('keystone'),                                                                                                                   
Gallery = keystone.list('Gallery'),
Image = keystone.list('Image');

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

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

// locals.section is used to set the currently selected
// item in the header navigation.
locals.section = 'home';
locals.galleries = [];

//Loading the galleries
view.on('init', function(next){

var q = Gallery.model.find()
.populate('heroImage images')
.sort('sortOrder');

q.exec(function(err, results) {
console.log(results);
locals.galleries = results;
next(err);
});
});


// Render the view
view.render('index');
};

查看模板:index.jade

//Portfolio section                                                                                                                               
section.grid#portfolio
if galleries.length
each gallery in galleries
if gallery.exists
figure.effect-portfolio.wow.fadeInDown(data-wow-duration="1500ms")
img(src=gallery._.heroImage.limit(680,680))

each image in gallery.images
figcaption
a(href=image.limit(1024,768), title=gallery.name, data-lightbox-gallery="gallery1", data-lightbox-hidpi=image.limit(300,300))
else
h4.text-muted There are no images to display

else
h4.text-muted There are no image galleries yet.

预先非常感谢您的帮助!

最佳答案

尝试不同的选项后,我找到了一个可行的解决方案。这可能不是最好的,所以如果有人提出任何补充意见,我将不胜感激。

工作解决方案:我只是修改了jade模板来更改图片源url。

//Portfolio section                                                                                                                               
section.grid#portfolio
if galleries.length
each gallery in galleries

figure.effect-portfolio.wow.fadeInDown(data-wow-duration="1500ms")
img(src="#{gallery.heroImage.image.secure_url}")

each image in gallery.images
figcaption
a(href="#{image.image.url}", title=gallery.name, data-lightbox-gallery=gallery.name, data-lightbox-hidpi="#{image.image.url}")

else
h4.text-muted There are no image galleries yet.

请注意,保留“if gallery.exists”声明不起作用。我不明白为什么......

关于node.js - 在 Keystone.js 中显示带有描述的图库图像时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39020201/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com