| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 开发测试 -> eggjs实战从0开始(4)-MVC改造 -> 正文阅读 |
|
[开发测试]eggjs实战从0开始(4)-MVC改造 |
1.操作数据库中间件:egg-mongooseegg框架后端代码操作mongodb数据库,需要借助中间件egg-mongoose,打开npm网站搜索,找到下载该中间件的官网,然后在项目中输入命令行下载:
然后参考官网插件使用提示,将代码改造成MVC模式。
为了更详细展示,我把文件全部代码贴出来:
和egg-mongoose官网介绍的代码略有不同,因为egg已经定义了exports对象,所以exports.mongoose的含义就是在其中定义一个mongoose对象。下面的nunjucks是后面要说的模板插件代码,对比两个代码可以发现,egg引入插件的方式大同小异。
为什么和官网代码略有不同,上面已经介绍过。 2.M(model)改造后app文件夹下的文件目录如图:
到此,一个最简单的包含三个字段的模型构造完成,复杂的模型无非也就是字段更多,字段本身的属性更多。 3.C(controller)为什么先记录C,而不是V,是因为根据我浅薄的后端知识,将前后端代码整体可以分为四个元素:
在浏览器输入接口地址:http://127.0.0.1:8080/news/list 4.V(view)本来想用art-template的,结果发现官网有个推荐的模板渲染,这种模板语法一般都差不多,主要是我懒,就不研究art-template了。
在config.default.js中写入:
至此,模板引擎下载并配置完毕。 使用模板引擎渲染页面:
newsData获取方式不变,定义一个变量ctxContent用来放我们要传递给前端的数据。其中result部分用es6解构的方式重新构造成一个数组。大家实际运行一下,将ctxContent打印出来,就知道为什么这么做了。
效果如图: 正常情况下,webstorm或者其他编程软件应该是不认识.nj后缀的,所以此类型文件没有代码提示,没有自动编码功能,以webstorm为例,通过设置,让ide在操作.nj文件时和.html文件一样。 |
|
开发测试 最新文章 |
pytest系列——allure之生成测试报告(Wind |
某大厂软件测试岗一面笔试题+二面问答题面试 |
iperf 学习笔记 |
关于Python中使用selenium八大定位方法 |
【软件测试】为什么提升不了?8年测试总结再 |
软件测试复习 |
PHP笔记-Smarty模板引擎的使用 |
C++Test使用入门 |
【Java】单元测试 |
Net core 3.x 获取客户端地址 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/17 20:18:45- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |