广州蓝景分享-如何习惯NodeJs的使用
ccwgpt 2024-11-05 09:30 30 浏览 0 评论
目前,在日常工作使用Node.js已经是很常用的啦,很多一线互联网公司都已实践,Node.js在开发效率和节省成本方面,对小公司尤其适用,成本也较低,很适合前端开发人员维护。下面就由广州蓝景的小编介绍一下。
Node.js是一个基于Chrome V8 引擎的 JavaScript 运行环境。V8 是 Google 发布的开源 JavaScript 引擎 ,本身就是用于 Chrome 浏览器的 JS 解释部分,但是 Ryan Dahl 这哥们,鬼才般的,把这个 V8 搬到了服务器上,用于做服务器的软件。
优势
Node.js使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。基于此NodeJs具有超强的高并发能力,因此,可以实现实现高性能服务器。
另外,NodeJs 语法完全是js语法,只要你懂js基础就可以学会Nodejs后端开发。Node 打破了过去 JavaScript 只能在浏览器中运行的局面。前后端编程环境统一,可以大大降低开发成本。
环境
在官网下载nodeJs(http://nodejs.cn/),最新版本为v10.13.0,建议node版本高于v7.6,因为后面我们会用到的koa2,要求node版本大于v7.6 。
更加推荐的方法是使用NVM来管理node版本。具体使用见蓝景电子书(蓝景电子书-一本有情怀的技术书籍),搜索“nvm”即可。
helloWorld
//helloWorld.js
console.log(“hello World!”)
//打开命令行并进入项目文件夹
node helloWorld.js
是不是非常简单!
开启一个服务器
我们在使用apach或者nginx,他们本身能提供一个服务器功能,用来处理请求.但在nodejs中,这个服务器需要我们自己来搭建,创建好服务器以后记得在浏览器里面访问他一下额.
//不支持import
const http = require(“http”);
let httpServer = http.createServer((request,response)=>{
console.log(“有访问来了”);
console.log(request.url);
console.log(request.headers);
console.log(request.method);
response.writeHead(200,“ok”,{“Content-Type”:“text/html;charset=UTF-8”});
response.write(“孩子浏览器已经接收到了你的请求”);
response.end();
});
//这里的host可以写成其他的"127.0.1.1"
httpServer.listen(3000,“localhost”);
上面代码是一个koa项目的基本组成结构,如果执行两次的话,是因为浏览器主动请求了"/favicon.icon"一次.下面我们看几个要注意的点:
app.listen(…) 只是一个语法糖
等价于下面的写法
//app.listen(…) 方法只是以下方法的语法糖:
const http = require(‘http’);
const Koa = require(‘koa’);
const app = new Koa();
http.createServer(app.callback()).listen(3000);
这意味着您可以将同一个应用程序同时作为 HTTP 和 HTTPS 或多个地址:
const http = require(‘http’);
const https = require(‘https’);
const Koa = require(‘koa’);
const app = new Koa();
http.createServer(app.callback()).listen(3000);
https.createServer(app.callback()).listen(3001);
app.use() 到底是个什么鬼,怎么回事?
首先,koa开启的web服务,每收到一个http请求,koa就会调用通过app.use()注册的async函数(当然也可以是普通函数),并传入ctx和next参数.这就是我们经常说的"中间件"了.
其次,可以多次调用use方法来注册中间件.
最后,use注册的async函数里面的next函数意义重大.当执行next()函数时,会将程序控制权(例如修改ctx.response.body)交给下一个中间件,下一个中间件再次调用next()函数,依次走下去.如果中间有一个中间件没有调用next()函数,那么后续的中间件就不会执行,当然最后中间件可以不执行next函数.
洋葱模型: 这里指的是next在中间件中调用的位置不同,代码执行的顺序也会不同.当中间件拿到控制权后,就开始执行use注册的async函数,当前async函数里面的代码,如果在next()调用前面会马上执行,如果代码在next()后面的话,就不要意思了,只能等下一个中间件执行完毕后再回来执行你了.简单点理解:next()就是执行下一个中间件,并且造成"阻塞".结合我们上述app.js的示例,你的网页会先输出"Bgg神教,一统江湖",后输出"hello,koa2",就是这个道理!
插播一条消息,你发现我们的示例ctx.response.body += "<h1>hello,koa2</h1>";是用的+=,说明多个组件其实控制的是同一个response.
async函数里面的ctx
ctx作为上下文使用,包括基本的ctx.request和ctx.response.为方便起见许多上下文的访问器和方法直接委托给它们的 ctx.request 或 ctx.response,不然的话它们是相同的. 例如 ctx.type 和 ctx.length 委托给 response 对象,ctx.path 和 ctx.method 委托给 request.
ctx.request/ctx.response 是 Koa 的 request/response 对象. ctx.req/ctx.res 是 node 的 request/response 对象,奇特吧!不过绕过 Koa 的 response 处理是不被支持的,所以避免使用ctx.res.write()等原生 response 操作.
除此之外,koa还约定了一个中间件的存储空间 ctx.state ,通过这个 state 可以储存一些数据,比如用户数据,另外类似 koa-views 这些渲染view层的中间件也会默认把 ctx.state 里面的属性作为 view 的上下文传入.如果使用webpack打包的话可以使用中间将加载资源的方法作为 ctx.state 的属性传入到view层使之获取资源路径.
拓展知识点
app.context
app.context 是从其创建 ctx 的原型。您可以通过编辑 app.context 为 ctx 添加其他属性。这对于将 ctx 添加到整个应用程序中使用的属性或方法非常有用,这可能会更加有效(不需要中间件)和/或 更简单(更少的 require()),而更多地依赖于ctx,这可以被认为是一种反模式。
例如,要从 ctx 添加对数据库的引用:
app.context.db = db();
app.use(async ctx => {
console.log(ctx.db);
});
错误处理
默认情况下,将所有错误输出到 stderr,除非 app.silent 为 true。 当 err.status 是 404 或 err.expose 是 true 时默认错误处理程序也不会输出错误。 要执行自定义错误处理逻辑,如集中式日志记录,您可以添加一个 “error” 事件侦听器:
app.on(‘error’, err => {
log.error(‘server error’, err)
});
//如果 req/res 期间出现错误,并且 无法 响应客户端,Context实例仍然被传递:
app.on(‘error’, (err, ctx) => {
log.error(‘server error’, err, ctx)
});
Request 别名
- ctx.header
- ctx.headers
- ctx.method
- ctx.method=
- ctx.url
- ctx.url=
- ctx.originalUrl
- ctx.origin
- ctx.href
- ctx.path
- ctx.path=
- ctx.query
- ctx.query=
- ctx.querystring
- ctx.querystring=
- ctx.host
- ctx.hostname
- ctx.fresh
- ctx.stale
- ctx.socket
- ctx.protocol
- ctx.secure
- ctx.ip
- ctx.ips
- ctx.subdomains
- ctx.is()
- ctx.accepts()
- ctx.acceptsEncodings()
- ctx.acceptsCharsets()
- ctx.acceptsLanguages()
- ctx.get()
Response 别名
- ctx.body
- ctx.body=
- ctx.status
- ctx.status=
- ctx.message
- ctx.message=
- ctx.length=
- ctx.length
- ctx.type=
- ctx.type
- ctx.headerSent
- ctx.redirect()
- ctx.attachment()
- ctx.set()
- ctx.append()
- ctx.remove()
- ctx.lastModified=
- ctx.etag=
想了解更多关于前端培训node.js框架的使用,可以在评论区留言,或者可以关注“广州蓝景”微信公众号 进行详细的了解。
相关推荐
- 一个基于.Net Core遵循Clean Architecture原则开源架构
-
今天给大家推荐一个遵循CleanArchitecture原则开源架构。项目简介这是基于Asp.netCore6开发的,遵循CleanArchitecture原则,可以高效、快速地构建基于Ra...
- AI写代码翻车无数次,我发现只要提前做好这3步,bug立减80%
-
写十万行全是bug之后终于找到方法了开发"提示词管理助手"新版本那会儿,我差点被bug整崩溃。刚开始两周,全靠AI改代码架构,结果十万行程序漏洞百出。本来以为AI说没问题就稳了,结果...
- OneCode低代码平台的事件驱动设计:架构解析与实践
-
引言:低代码平台的事件驱动范式在现代软件开发中,事件驱动架构(EDA)已成为构建灵活、松耦合系统的核心范式。OneCode低代码平台通过创新性的注解驱动设计,将事件驱动理念深度融入平台架构,实现了业务...
- 国内大厂AI插件评测:根据UI图生成Vue前端代码
-
在IDEA中安装大厂的AI插件,打开ruoyi增强项目:yudao-ui-admin-vue31.CodeBuddy插件登录腾讯的CodeBuddy后,大模型选择deepseek-v3,输入提示语:...
- AI+低代码技术揭秘(二):核心架构
-
本文档介绍了为VTJ低代码平台提供支持的基本架构组件,包括Engine编排层、Provider服务系统、数据模型和代码生成管道。有关UI组件库和widget系统的信息,请参阅UI...
- GitDiagram用AI把代码库变成可视化架构图
-
这是一个名为gitdiagram的开源工具,可将GitHub仓库实时转换为交互式架构图,帮助开发者快速理解代码结构。核心功能一键可视化:替换GitHubURL中的"hub...
- 30天自制操作系统:第六天:代码架构整理与中断处理
-
1.拆开bootpack.c文件。根据设计模式将对应的功能封装成独立的文件。2.初始化pic:pic(可编程中断控制器):在设计上,cpu单独只能处理一个中断。而pic是将8个中断信号集合成一个中断...
- AI写代码越帮越忙?2025年研究揭露惊人真相
-
近年来,AI工具如雨后春笋般涌现,许多人开始幻想程序员的未来就是“对着AI说几句话”,就能轻松写出完美的代码。然而,2025年的一项最新研究却颠覆了这一期待,揭示了一个令人意外的结果。研究邀请了16位...
- 一键理解开源项目:两个自动生成GitHub代码架构图与说明书工具
-
一、GitDiagram可以一键生成github代码仓库的架构图如果想要可视化github开源项目:https://github.com/luler/reflex_ai_fast,也可以直接把域名替换...
- 5分钟掌握 c# 网络通讯架构及代码示例
-
以下是C#网络通讯架构的核心要点及代码示例,按协议类型分类整理:一、TCP协议(可靠连接)1.同步通信//服务器端usingSystem.Net.Sockets;usingTcpListene...
- 从复杂到优雅:用建造者和责任链重塑代码架构
-
引用设计模式是软件开发中的重要工具,它为解决常见问题提供了标准化的解决方案,提高了代码的可维护性和可扩展性,提升了开发效率,促进了团队协作,提高了软件质量,并帮助开发者更好地适应需求变化。通过学习和应...
- 低代码开发当道,我还需要学习LangChain这些框架吗?| IT杂谈
-
专注LLM深度应用,关注我不迷路前两天有位兄弟问了个问题:当然我很能理解这位朋友的担忧:期望效率最大化,时间用在刀刃上,“不要重新发明轮子”嘛。铺天盖地的AI信息轰炸与概念炒作,很容易让人浮躁与迷茫。...
- 框架设计并不是简单粗暴地写代码,而是要先弄清逻辑
-
3.框架设计3.框架设计本节我们要开发一个UI框架,底层以白鹭引擎为例。框架设计的第一步并不是直接撸代码,而是先想清楚设计思想,抽象。一个一个的UI窗口是独立的吗?不是的,...
- 大佬用 Avalonia 框架开发的 C# 代码 IDE
-
AvalonStudioAvalonStudio是一个开源的跨平台的开发编辑器(IDE),AvalonStudio的目标是成为一个功能齐全,并且可以让开发者快速使用的IDE,提高开发的生产力。A...
- 轻量级框架Lagent 仅需20行代码即可构建自己的智能代理
-
站长之家(ChinaZ.com)8月30日消息:Lagent是一个专注于基于LLM模型的代理开发的轻量级框架。它的设计旨在简化和提高这种模型下代理的开发效率。LLM模型是一种强大的工具,可以...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- mfc框架 (52)
- abb框架断路器 (48)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- tornado框架 (48)
- 前端框架bootstrap (54)
- orm框架有哪些 (51)
- 知识框架图 (52)
- ppt框架 (55)
- 框架图模板 (59)
- 内联框架 (52)
- cad怎么画框架 (58)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)