Vapor模板leaf的使用

添加Leaf中间件
  1. Package.swift添加资源路径
.Package(url: "https://github.com/vapor/leaf-provider.git", majorVersion: 1)
  1. 在droplet.json文件声明
  "view" : "leaf"
  1. Config+Setup.swift文件中添加到Droplet
    /// Configure providers
    private func setupProviders() throws {
        try addProvider(FluentProvider.Provider.self)
        try addProvider(MySQLProvider.Provider.self)
        try addProvider(LeafProvider.Provider.self)
    }
  1. 创建Resources文件,文件夹下创建views文件夹保存模板文件
    list.png
Leaf的语法
  • leaf的标签有四种元素构成
    • # leaf模板标签的标识
    • name 字符串类型标签名
    • () 参数列表,可接受0个或多个参数
    • {} 标签功能执行体,可选,但是与必须参数列表用一个空格隔开
  • 实例
    • #()
    • #(variable)
    • #import("template")
    • #export("link") { <a href="#()"></a> }
    • #index(friends, "0")
    • #loop(friends, "friend") { <li>#(friend.name)</li> }
    • #raw() { <a href="#raw">Anything goes!@#$%^&*</a> }
 #import("footer")
    <body>
        <h1>Welcome #(name)</h1>
        <h2>#(description)</h2>
        #loop(users,"userName"){
            <li>#(userName)</li>
        }
    </body>
#import("head")
  • 模板的渲染
 static func indexUser(_request: Request) throws -> ResponseRepresentable {
        let user = try User.makeQuery().all()   // 表的字段或对应的值最好不要包含`.` DotKey
        for us in user {
            print(us.name)
        }
        let userName = user.map{$0.name}
        return try droplet.view.make("index", ["name" : "SunnyHC","description" : "Leaf","users" : userName])
    }
leaf.png

查看更多Leaf资料

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,241评论 4 61
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 13,934评论 0 15
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,923评论 18 139
  • 大城市的喧嚣还在继续,小县城却早已夜深人静。小半年的时光,还未习惯早早向世界道一声晚安。 周五的夜,原本是狂欢的夜...
    67度仰望天空阅读 96评论 0 0
  • 大学有个室友A,身材高挑,颜值也挺高的,大一刚进来就被室友B夸得天花乱坠,什么女神啊、撑起整个班的颜值担当啊…我的...
    一棵藤上七朵花阅读 272评论 0 0