node.js知识点(随意写)

知识点

  • 客户端:在浏览器中运行的部分,就是用户看到并与之交互的界面程序。使用HTML、CSS、- JavaScript构建。
  • 服务器端:在服务器中运行的部分,负责存储数据和处理应用逻辑。
  • 统一资源定位符,又叫URL(Uniform Resource Locator),是专为标识Internet网上资源位置而设的一种编址方式,我们平时所说的网页地址指的即是URL
  • package.json
    记录当前项目信息
  • package-lock.json
    1.锁定包的版本
    2.加快下载速度
  • 在package.json取别名
  • ip地址
  • 域名:网址
  • 端口(pid):使用端口区分不同的服务,每一个向往提供服务的软件,都是要占用个端口
  • 创建web服务器
  • nodemon自动更新命令

http协HTTP协议!重点

  • HTTP协议的概念

超文本传输协议(英文:HyperText Transfer Protocol,缩写:HTTP)规定了如何从网站服务器传输超文本到本地浏览器,它基于客户端服务器架构工作,是客户端(用户)和服务器端(网站)请求和应答的标准。

  • 报文

在HTTP请求和响应的过程中传递的数据块就叫报文,包括要传送的数据和一些附加信息,并且要遵守规定好的格式。

请求报文
请求方式 post
请求地址 www.ithcast.com
Hello, 请给我一个好消息!

响应报文
内容类型 text/html
内容长度 20
Hi, 我就是好消息 !

请求方式 (Request Method)

GET 请求数据
POST 发送数据

  • 请求报文
    req.url获取请求地址
    req.header获取请求信息
    req.method获取请求方式
    res.end响应数据

  • 响应报文

  1. HTTP状态码(res.writeHead(设置http状态码,{响应报文}))
    200 请求成功
    404 请求的资源没有被找到
    500 服务器端错误
    400 客户端请求有语法错误

  2. 内容类型
    text/html
    text/css
    application/javascript
    image/jpeg
    application/json

请求参数

  • GET请求参数

参数被放置在浏览器地址栏中,例如:http://localhost:3000/?name=zhangsan&age=20

参数获取需要借助系统模块url,url模块用来处理url地址

扫描二维码关注公众号,回复: 6746717 查看本文章
 const http = require('http');

 // 导入url系统模块 用于处理url地址
 
const url = require('url');
 
const app = http.createServer();
  
app.on('request', (req, res) => {
     
// 将url路径的各个部分解析出来并返回对象
        
 // true 代表将参数解析为对象格式
    
 let params = url.parse(req.url, true);
     
console.log(params.name);

 });
 
app.listen(3000);
  • post请求参数(分批传输数据)

参数被放置在请求体中进行传输

获取POST参数需要使用data事件和end事件

使用querystring系统模块将参数转换为对象格式

资源

静态资源
服务器端不需要处理,可以直接响应给客户端的资源就是静态资源,例如CSS、JavaScript、image文件

动态资源
相同的请求地址不同的响应资源,这种资源就是动态资源。

异步函数

同步API:只有当前API执行完成后,才能继续执行下一个API

异步API:当前API的执行不会阻塞后续代码的执行

先执行同步,在执行异步API

console.log('代码开始执行'); 

setTimeout(() => { console.log('2秒后执行的代码')}, 2000);
------通过回调函数队列从异步代码队列放到同步队列

setTimeout(() => { console.log('"0秒"后执行的代码')}, 0); 

console.log('代码结束执行');

结果:代码开始执行-代码结束执行-0-2


异步编程

Promise出现的目的是解决Node.js异步编程中回调地狱的问题。

  • async关键字
  1. 普通函数定义前加async关键字 普通函数变成异步函数

  2. 异步函数默认返回promise对象

  3. 在异步函数内部使用return关键字进行结果返回 结果会被包裹的promise对象中 return关键字代替了resolve方法

  4. 在异步函数内部使用throw关键字抛出程序异常

  5. 调用异步函数再链式调用then方法获取异步函数执行结果

  6. 调用异步函数再链式调用catch方法获取异步函数执行的错误信息

  • await关键字
  1. await关键字只能出现在异步函数中

  2. await promise await后面只能写promise对象 写其他类型的API是不不可以的

  3. await关键字可是暂停异步函数向下执行 直到promise返回结果

猜你喜欢

转载自blog.csdn.net/weixin_44683763/article/details/94620818