码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Egg 1. 快速开始 Quick Start 1.3 一步步 Step by Step 1.3.3 添加静态资源 & 1.3.4 添加渲染模板


    Egg

    Egg

    本文仅用于学习记录,不存在任何商业用途,如侵删

    文章目录

        • Egg
        • 1. 快速开始 Quick Start
          • 1.3 一步步 Step by Step
            • 1.3.3 添加静态资源
            • 1.3.4 添加渲染模板

    1. 快速开始 Quick Start

    1.3 一步步 Step by Step
    1.3.3 添加静态资源

    Egg 有一个名为static的内置插件。

    在这里插入图片描述

    在生产中,建议您将静态资产部署到 CDN,而不是使用此插件。

    static默认映射/public/*到目录app/public/*。

    在这种情况下,我们只需要将静态资产放入目录app/public中。

    app/public
    ├── css
    │ └── news.css
    └── js
    ├── lib.js
    └── news.js

    举个例子:

    在这里插入图片描述

    重启服务测试:

    在这里插入图片描述

    没毛病。

    1.3.4 添加渲染模板

    在大多数情况下,数据通常在呈现给用户之前由模板读取、处理和呈现。

    因此我们需要引入相应的模板引擎来处理它。

    Egg 不强制使用任何特定的模板引擎,而是指定View Plugins Specification以允许开发人员使用不同的插件来满足他们的个人需求。

    在这里插入图片描述

    有关更多信息,请参阅。查看.

    在这里插入图片描述

    在本例中,我们将使用Nunjucks。

    在这里插入图片描述

    首先安装对应的插件,egg-view-nunjucks

    在这里插入图片描述

    $ npm i egg-view-nunjucks --save
    
    • 1

    在这里插入图片描述

    启用它:

    // config/plugin.js
    exports.nunjucks = {
      enable: true,
      package: 'egg-view-nunjucks',
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    // config/config.default.js
    exports.keys = ;
    // add view's configurations
    exports.view = {
      defaultViewEngine: 'nunjucks',
      mapping: {
        '.tpl': 'nunjucks',
      },
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    在这里插入图片描述

    这个配置要小心,config目录,不是app/config

    在这里插入图片描述

    然后为index页面创建一个模板。这通常进入 app/view 目录。

    
    
      
        Egg HackerNews Clone
        
      
      
        
      {% for item in list %}
    • {{ item.title }}
    • {% endfor %}
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在这里插入图片描述

    然后添加控制器和路由器:

    const Controller = require('egg').Controller;
    
    class NewsController extends Controller{
        async list(){
            const dataList = {
                list: [
                    {id:1,title:'这是新闻1',url:'/news/1'},
                    {id:2,title:'这是新闻2',url:'/news/2'},
                ],
            };
            await this.ctx.render('news/list.tpl',dataList);
        }
    }
    
    module.exports = NewsController;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    在这里插入图片描述

    在这里插入图片描述

    重启服务,访问路径 http://localhost:7001/news

    在这里插入图片描述

    提示:在开发中,Egg 默认启用开发插件,当您的后端代码发生更改时,它会重新加载您的工作进程。

    在这里插入图片描述

    不错

  • 相关阅读:
    [附源码]java毕业设计大学新生军训管理系统
    vue+flv.js+SpringBoot+websocket实现视频监控与回放
    Nginx学习笔记09——URLRewrite伪静态
    Scala 环境搭建
    buildSrc 定义插件(1)
    Qunar风控安全产品的探索之路
    2022BATJ1000 道 Java 面试题解析,已有 372 人上岸(必看攻略)
    常见希腊字母
    SpringMVC使用
    少林派问题汇总2
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/128157391
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号