位置: IT常识 - 正文

【node进阶】浅析Koa框架---ejs模板|文件上传|操作mongoDB(node教程)

编辑:rootadmin
【node进阶】浅析Koa框架---ejs模板|文件上传|操作mongoDB

推荐整理分享【node进阶】浅析Koa框架---ejs模板|文件上传|操作mongoDB(node教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node入门教程,node教程,node _,nodejs进阶,nodejs进阶,node实战,node 入门,node入门教程,内容如对您有帮助,希望把文章链接给更多的朋友!

✅ 作者简介:一名普通本科大三的学生,致力于提高前端开发能力 ✨ 个人主页:前端小白在前进的主页 🔥 系列专栏 : node.js学习专栏 ⭐️ 个人社区 : 个人交流社区 🍀 学习格言: ☀️ 打不倒你的会使你更强!☀️ 💯 刷题网站:这段时间有许多的小伙伴在问有没有什么好的刷题网站,博主在这里给大家推荐一款刷题网站:👉点击访问牛客网👈牛客网支持多种编程语言的学习,各大互联网大厂面试真题,从基础到拔高,快来体验一下吧!

🔥前言

koa框架中的ejs模板使用方式与express并无差距,文件上传、操作mongoDB也并没有很多不一样的东西,本篇文章更着重于代码,ejs模板在文章express应用程序生成器中已经做了讲解,文件上传在文章Express+Multer+Postman模拟文件上传功能中也做了讲解,node连接mongoDB暂时还没出文章,这里的话先给大家说一下怎么去操作mongoDB,后续会出文章补充mongoDB和MYSQL。

📃目录ejs模板上传文件操作mongoDB小结ejs模板

安装koa-views中间件

npm install --save koa-views

koa-views 是一个视图管理模块,它的灵活度很高,支持很多的模版引擎,这里我们给它配置的引擎是 ejs。

安装ejs模板引擎

npm install --save ejs

文件目录

├── package.json ├── index.js(入口文件) └── view(视图管理文件夹) ------└── index.ejs(ejs模板页面)

index.js(入口文件)

const Koa = require('koa')const views = require('koa-views')const path = require('path')const app = new Koa()// 加载模板引擎app.use(views(path.join(__dirname, './view'), { extension: 'ejs'}))app.use( async ( ctx ) => { let title = 'hello koa2' await ctx.render('index', { title, })})app.listen(3000)

index.ejs 模板页面

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title></head><body> <h1>home模板页面</h1> <div>欢迎使用<%= title%></div></body></html>【node进阶】浅析Koa框架---ejs模板|文件上传|操作mongoDB(node教程)

最终效果

上传文件

安装@koa/multer multer

npm install --save @koa/multer multer

在这里很多人感到不解,为什么安装了@koa-multer中间件后还要安装multer,这是因为@koa/multer中间件是依赖于multer而创建的,所以必须要下载multer

上传页面代码

<form action="/upload" method="POST" enctype="multipart/form-data"> <div> 头像:<input type="file" name="avatar"> </div> <div> <input type="submit" value="提交"> </div> </form>

关键逻辑代码

const multer = require('@koa/multer');//自动在public目录下生成文件夹uploads,在这里存储图片const upload = multer({ dest: 'public/uploads/' })//路由代码router.post("/upload",upload.single('avatar'),(ctx,next)=>{ console.log(ctx.request.body,ctx.file) ctx.body={ ok:1, info:"add user success" }})

我们点击提交按钮后,图片的存放路径就给出来了,我们可以在public/uploads中找到我们上传的图片. (谨记:我们得到的图片是没有后缀名的,如果想要在网页中打开图片,必须要自定义存储引擎!)

操作mongoDB

虽然在之前的文章中没有涉及到数据库,是因为考虑到想把mongoDB和MYSQL两种数据库连着出文章,便于大家去做一个对比,在本文中就先简单的让大家明白koa怎么连接mongoDB。

文件目录

├── package.json ├── index.js(入口文件) └── config ------└── db.config.js(数据库配置文件) └──model ------└── UserModel.js(数据库模型文件)

安装mongoose模块

npm i mongoose

db.config.js(数据库配置文件)

//连接数据库const mongoose = require("mongoose")mongoose.connect("mongodb://127.0.0.1:27017/lzq_koa")//插入集合和数据,数据库lzq_koa会自动创建

UserModel.js(数据库模型文件)

const mongoose = require("mongoose")const Schema = mongoose.Schemaconst UserType = { username:String, password:String, age:Number, avatar:String}const UserModel = mongoose.model("user",new Schema(UserType))// 模型user 将会对应 users 集合, module.exports = UserModel小结

这篇文章最不合理的地方在于之前没有出在node中学习简单的mongoDB操作的文章,就会导致本篇的操作mongoDB小节中大家可迷,但是希望大家谅解一下,主要是想把数据库在node学习专栏中最后去出,希望各位可以体谅一下!koa框架中只少了最后一个模块没出了,它就是身份认证,下篇文章会给大家奉上的!

本文链接地址:https://www.jiuchutong.com/zhishi/299198.html 转载请保留说明!

上一篇:Sklearn GridSearchCV跑SVM很慢或卡死解决办法,SVM线性核函数卡死

下一篇:vue 遍历数组(vue遍历数组)

  • 递延所得税资产和所得税费用的关系
  • 建筑业固定资产折旧费用科目是什么
  • 借款入账会计分录
  • 小规模纳税人补税怎么补
  • 固定资产累计折旧是什么科目
  • 开票不确认收入可以吗
  • 法人名下的车辆费用如何进公司帐
  • 累计折旧和固定资产减值准备的区别
  • 设计原始凭证所需内容及步骤
  • 代收税款
  • 应收票据的会计分录例题
  • 出售商标使用权收入计入什么科目
  • 购买无形资产的价款超过正常信用
  • 营改增对建筑行业税负的影响
  • 房地产企业增值税预缴
  • 当期销项税额等于什么乘以什么
  • 固定资产清理销项税
  • 收到住房补贴怎么做账
  • 抄报税失败不许逾期报税吗
  • 补贴收入是否缴税
  • 季度不含税收入30万以内免增值税
  • 增值税销项税额抵减账务处理
  • 剑灵配置要求2020官方
  • win10家庭最新版
  • 对增值税发票开具方面有何要求?
  • npm sill idealTree buildDeps 安装踩坑指南(详细版)
  • 劳务费和服务费税率一样吗
  • php数组函数,选班长
  • 客户预付款了尾款怎么办
  • vnisedit 打包
  • 公司购买二手车需要交什么税
  • 孚日山脉猞猁
  • 篱笆的样子
  • seata+nacos
  • 总结一些php中好用的软件
  • 微前端Qiankun 子应用css后加载问题
  • 百度地图 申请
  • pytorch创建模型
  • mysqlbinlog -vv
  • 入库税款异常怎么处理
  • 进项大于销项怎么办
  • 报表里主营业务怎么填
  • 房产税在企业所得税扣除内吗
  • 不应确认增值税销项税额的
  • 出口属于什么行业
  • sql按分隔符截取
  • 哪种发票可以报税
  • 分期付款服务费是什么
  • 去年多计提的所得税怎么处理
  • 公司交社保有什么用处
  • 机场员工家属机票
  • 财务报销单据粘贴视频
  • 其它权益工具投资和其他债权投资
  • 递延所得税资产是什么意思
  • 长期股权投资的交易费用计入哪里
  • 代扣代缴个人所得税分录
  • 会计主体包括哪些四种
  • 账务处理程序和财务处理程序
  • mysql5.7卸载重装
  • ubuntu下source、sh、bash、./执行脚本的区别详细介绍
  • skydrive官网登录
  • 惠普装xp系统
  • win7开始菜单中的程序图标修改了
  • es6 变量的解构赋值
  • jquery 动态加载js
  • unet遥感图像分割
  • cocoscreator shader
  • Html5+jQuery+CSS制作相册小记录
  • unity3dextractor
  • jquery常用选择器种类
  • 安卓全局替换
  • javascript教程完整版
  • javascript基础入门视频教程
  • 安卓各版本占比统计图
  • 移交税务稽查的条件标准
  • 中国移动的电子协议推送服务是什么
  • 河北省税务局稽查局领导班子
  • 小规模纳税人公司买车能抵多少税
  • 金三申报系统里面怎么申报社保?
  • 财务制度备案表单怎么填
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设