热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

koa2从入门到进阶之路(四)

之前的文章我们介绍了一下koa中间件以及koa中间件的洋葱图执行流程,本篇文章我们来看一下koa中使用ejs模板及页面渲染。在Express中,我们经常

之前的文章我们介绍了一下 koa 中间件 以及 koa 中间件的洋葱图执行流程,本篇文章我们来看一下 koa 中使用 ejs 模板及页面渲染。

在 Express 中,我们经常会用 ejs 模板来渲染前端页面,在 koa 中同样可以使用 ejs 模板引擎,关于 ejs 模板引擎的用法这里就不做过多说明了,https://ejs.bootcss.com/,这是官网,为我们做了详细的教程。

在 koa 中使用 ejs 我们需要安装 koa-views 和 ejs 两个模块:

安装 koa-views npm installkoa-views --save  / cnpm install koa-views --save

安装 ejs npm install ejs --save / cnpm install ejs --save

然后就可以在我们的项目中配置和使用了,我们在之前的项目中将 app.js 改为如下:

1 //引入 koa模块
2 const Koa = require('koa');
3 const Router = require('koa-router');
4 const views = require('koa-views');
5
6 //实例化
7 const app = new Koa();
8 const router = new Router();
9
10 //配置模板引擎中间件
11
12 // 模板的后缀名是.html
13 // app.use(views('views', {
14 // map: {html: 'ejs'}
15 // }));
16 // 模板的后缀名是.html
17 app.use(views('views', {
18 extension: 'ejs'
19 }));
20
21 //写一个中间件配置公共的信息
22 app.use(async (ctx, next) => {
23 ctx.state.commonData = "这是一个公有数据,每个页面都能引用";
24 // 继续向下匹配路由
25 await next();
26 });
27
28 router.get('/', async (ctx) => {
29 let title = "hello world";
30 let list = ["aaa", "bbb", "ccc"];
31
32 await ctx.render('index', {
33 title,
34 list,
35 });
36 });
37
38 router.get('/news', async (ctx) => {
39 await ctx.render('news', {});
40 });
41
42 //启动路由
43 app.use(router.routes());
44 app.use(router.allowedMethods());
45
46 app.listen(3000);

首先在模块中引入 koa-views;然后我们用中间件 app.use("views",{ }) 的形式引入 ejs 模板引擎,其中注释掉的为第一种,是以 .html 结尾,第二种是以 .ejs 结尾。

"views" 是我们要指定的目录,我们写成 "views",就需要在项目目录中创建一个 views 目录来存放我们的 ejs 文件。  

之后我们写了一个应用级中间件来存放一个共有的数据,这个中间件可以去上一篇文章看一下具体作用,这里不过多解释。

然后我们在 router.get("/", ) 路由中存放了两条数据,一条字符串,一条数组。

我们不再使用 stx.body="" 的方式向前端输出内容,而是使用 ctx.render("index",{ }) 形式向前端输出内容,其中 "idenx" 为我们在 "views" 目录中定义的 index.ejs 的文件名称,{ } 内为我们要传入的数据。

剩下的内容就和我们之前项目的一样即可,我们再来看一下现在的项目目录:

如果我们在 views 目录中定义的以 .html 结尾,将上面代码的 html 注释解开,将 ejs 注释掉即可。

然后我们来看一下 index.ejs 中的代码:

1 DOCTYPE html>
2 <html lang&#61;"en">
3 <head>
4 <meta charset&#61;"UTF-8">
5 <title>title>
6 head>
7 <body>
8 <% include blocks/header.ejs %>
9 <p><%&#61; commenData %>p>
10 <p><%&#61; title %>p>
11 <ul>
12 <% for(var i &#61; 0;i < list.length;i&#43;&#43;){ %>
13 <li><%&#61; list[i] %>li>
14 <% } %>
15 ul>
16 body>
17 html>

news.ejs 

1 DOCTYPE html>
2 <html lang&#61;"en">
3 <head>
4 <meta charset&#61;"UTF-8">
5 <title>title>
6 head>
7 <body>
8 <% include blocks/header.ejs %>
9 <h2><%&#61; commonData %>h2>
10 body>
11 html>

blocks/header.ejs

<h1>这是一个头部的模块h1>

关于 ejs 文件内的运算符号 <%%> 在这里就不做过多解释了&#xff0c;大家可以去 ejs 官网学习&#xff0c;不是很难。

最终结果如下&#xff1a;

 

 

可以看出我们的 ejs 模板引擎运行的没有问题&#xff0c;数据也都正常显示在了页面中。

 


转载于:https://www.cnblogs.com/weijiutao/p/10691481.html


推荐阅读
  • loader资源模块加载器webpack资源模块加载webpack内部(内部loader)默认只会处理javascript文件,也就是说它会把打包过程中所有遇到的 ... [详细]
  • 本文介绍了JavaScript进化到TypeScript的历史和背景,解释了TypeScript相对于JavaScript的优势和特点。作者分享了自己对TypeScript的观察和认识,并提到了在项目开发中使用TypeScript的好处。最后,作者表示对TypeScript进行尝试和探索的态度。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • VueCLI多页分目录打包的步骤记录
    本文介绍了使用VueCLI进行多页分目录打包的步骤,包括页面目录结构、安装依赖、获取Vue CLI需要的多页对象等内容。同时还提供了自定义不同模块页面标题的方法。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • Node.js学习笔记(一)package.json及cnpm
    本文介绍了Node.js中包的概念,以及如何使用包来统一管理具有相互依赖关系的模块。同时还介绍了NPM(Node Package Manager)的基本介绍和使用方法,以及如何通过NPM下载第三方模块。 ... [详细]
  • node.jsrequire和ES6导入导出的区别原 ... [详细]
author-avatar
AMY_Only
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有