Я пытался визуализировать вычисляемое свойство, используя шаблонизатор Leaf с Vapor 3, но пока что не повезло.Если хранится одно и то же свойство, все работает нормально.Если я сделаю его вычисленным, на веб-странице ничего не отобразится.Я могу понять причины, по которым такое решение не будет работать, но я хотел бы знать, есть ли способ заставить его работать.
Код для элемента для визуализации :
struct SocialLinkContext: Encodable, CSSStyleable {
let hyperlinkURI: String
let classes: [String]
//let styleClasses: String
init(hyperlinkURI: String, classes: [String]) {
self.hyperlinkURI = hyperlinkURI
self.classes = classes
//self.styleClasses = classes.joined(separator: " ")
}
//Seems not to be supported by Leaf
var styleClasses: String {
return self.classes.joined(separator: " ")
}
}
Часть файла main_page.leaf :
...
<div class="row banner">
<div class="banner-text">
<h1 class="responsive-headline">Hello, world!</h1>
<hr />
</div>
#embed("social_links")
</div>
...
Файл social_links.leaf :
<ul class="social">
#for(socialContext in socialLinks) {
<li>
<a href="#(socialContext.hyperlinkURI)">
<i class="#(socialContext.styleClasses)"></i>
</a>
</li>
}
</ul>
PersonalPageContext для передачи в средство визуализации представлений:
struct PersonalWebPageContext: Encodable {
...
let socialLinks: [SocialLinkContext] = [...]
...
}
И, наконец, контроллер PersonalWebPageViewController :
private func serveWebPage(req: Request) throws -> Future<View> {
return try req.view().render("main_page", PersonalWebPageContext())
}