首页 >> 大全

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

2023-09-02 大全 30 作者:考证青年

✅ 作者简介:一名普通本科大三的学生,致力于提高前端开发能力

✨ 个人主页:前端小白在前进的主页

系列专栏 : node.js学习专栏

⭐️ 个人社区 : 个人交流社区

学习格言: ☀️ 打不倒你的会使你更强!☀️

刷题网站:这段时间有许多的小伙伴在问有没有什么好的刷题网站,博主在这里给大家推荐一款刷题网站:点击访问牛客网牛客网支持多种编程语言的学习,各大互联网大厂面试真题,从基础到拔高,快来体验一下吧!

前言

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

目录

ejs模板

文件目录

├── .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>

最终效果

上传文件

上传页面代码

<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"}
})

我们点击提交按钮后,图片的存放路径就给出来了,我们可以在/中找到我们上传的图片.

(谨记:我们得到的图片是没有后缀名的,如果想要在网页中打开图片,必须要自定义存储引擎!)

操作

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

_文件上传模块_上传模块

文件目录

├── .json

├── index.js(入口文件)

└──

------└── db..js(数据库配置文件)

└──model

------└── .js(数据库模型文件)

安装模块

npm i mongoose

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

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

.js(数据库模型文件)

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

小结

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

关于我们

最火推荐

小编推荐

联系我们


版权声明:本站内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 88@qq.com 举报,一经查实,本站将立刻删除。备案号:桂ICP备2021009421号
Powered By Z-BlogPHP.
复制成功
微信号:
我知道了