Node.js基础篇-01

Node.js的的优点: 1、可以快速获得可视化的结果 2、非常轻量级,几乎可以安装到各个平台 3、强大社区支持 Node.js的交互模式: Node.js的交互模式是 读取-求值-打印-循环 read-eval-print loop(REPL)模式,用图表示流程如下

Node.js模块系统

Node.js支持两种不同的模块系统,之前的方式是CommonJS module,通过module.exports去导出需要的元素或者方法。另一种是ECMAScript module,使用import和export搭配使用,不兼容CommonJS module形式。注意:使用ECMAScript module要记得在package.json中添加"type": "module",

创建一个最基本的web服务

1、引入http模块,创建服务 2、监听端口号,执行回调

javascript 复制代码
import {createServer} from 'http'

const server = createServer()

server.listen(6677, () => {
  console.log('服务已启动在5566端口');
})

扩展web服务

在创建服务时加上,request和response的回调处理

javascript 复制代码
import {createServer} from 'http'

const server = createServer((request, response) => {
  response.writeHead(200, { 'content-type': 'text/plain; charset=utf-8' })
  response.write('sugar ')
  response.end('high')
})

server.listen(6677, () => {
  console.log('服务已启动在5566端口');
})

request:客户端的请求 response:服务器的响应 HTTP头:writeHead的参数1:参数状态码、参数2:是一个键值对象,包括内容类型content-type,字符集。 创建响应:在HTTP的body内,通过write方法进行创建,当方法被调用,这个片段代码就会被执行被发送 write方法有两个需要注意的特点:1、不仅可以将字符串作为参数传递,也可以作为缓存对象传递 2、字符串编码,比如utf-8

常用命令

初始化Node.js

npm init -y

会创建一个package.json

package.json简介

name:包名 每个包名在npm上都是独一无二的,一般由小写字母与连字符 - 构成 version:描述包版本,通常结构是x.x.x 对应 major.minor.patch major:主版本号,不兼容的API修改时 minor:次版本号,向下兼容的功能性新增 patch:修订号,向下兼容的问题修复 main:表示包的入口文件 script:用于设置自定义脚本 keywords:用于检索的关键词 dependencies:依赖

模块的加载时机

  • CJS 支持动态加载模块 (require 语句可以出现在任意位置);
  • ESM 会在所有模块都加载完毕后才执行代码 (通常会将 import 导入语句放在模块的顶部);
    • ESM 是静态解析的,它会在编译时首先解析模块中的导入语句,虽然通常会将导入语句放在模块的顶部,但并不是要求所有的 import 语句必须在文件顶部,只要在使用导入的内容之前进行导入即可。

全局变量

global对象 常用global属性 1、process:进程相关控制 打印process.arvg会得到以下数组,包含启动 Node.js 进程时传递的命令行参数 参数1:Node在机器的位置 参数2:执行文件的绝对路径 process.env执行环境的环境变量 2、Buffer:处理二进制数据

相关推荐
理想不理想v几秒前
vue经典前端面试题
前端·javascript·vue.js
小阮的学习笔记15 分钟前
Vue3中使用LogicFlow实现简单流程图
javascript·vue.js·流程图
YBN娜15 分钟前
Vue实现登录功能
前端·javascript·vue.js
阳光开朗大男孩 = ̄ω ̄=15 分钟前
CSS——选择器、PxCook软件、盒子模型
前端·javascript·css
一只爱打拳的程序猿17 分钟前
【Spring】更加简单的将对象存入Spring中并使用
java·后端·spring
小政爱学习!41 分钟前
封装axios、环境变量、api解耦、解决跨域、全局组件注入
开发语言·前端·javascript
魏大帅。1 小时前
Axios 的 responseType 属性详解及 Blob 与 ArrayBuffer 解析
前端·javascript·ajax
花花鱼1 小时前
vue3 基于element-plus进行的一个可拖动改变导航与内容区域大小的简单方法
前端·javascript·elementui
k09331 小时前
sourceTree回滚版本到某次提交
开发语言·前端·javascript
web行路人1 小时前
React中类组件和函数组件的理解和区别
前端·javascript·react.js·前端框架