IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> [Node]node.js全栈入门[上] -> 正文阅读

[JavaScript知识库][Node]node.js全栈入门[上]

背景

补充学习下node知识,课程来自imooc
从node基础到web相关的基础知识,到最后任务管理系统实战。
技术栈:react+redux+mysql+express
个人学习笔记,如有侵权,会删除。

笔记

node基础

  1. 创建一个nodejs程序

    //读取系统的cpu的信息
    const os = require('os');
    //获取当前系统的cpu数量
    const cpus = os.cpus();
    console.log(cpus.length);
    //获取内存的信息
    //总内存,GB
    const total = os.totalmem();
    console.log(total / 1024 / 1024 / 1024);
    //剩余内存,GB
    const free = os.freemem();
    console.log(free / 1024 / 1024 / 1024);
    
    //web服务
    //ajax->api->web server(nodejs)
    const http = require('http');
    //创建服务实例
    //req 请求对象
    //res 响应对象
    const server = http.createServer((req, res) => {
       res.statusCode = 200;
       res.setHeader('Content-Type', 'text/plain');
       res.end('Hello');
    })
    server.listen(3000, '127.0.0.1', () => {
       //回调
       console.log('服务启动了')
    })
    
    //启动服务
    //node 1-nodejs.js
    
    1. nodejs 和npm
      js调用nodejs的api
      npm 安装第三方包
      v8 引擎
      libuv开发包,异步io(文件读取,http请求),实现非堵塞;事件驱动
      底层调用os
      在这里插入图片描述
  2. nodemon 监听文件变化,自动重启服务
    node在启动前,会把所有文件解析掉,以此提高性能,效率。所以每次更新后,需要重新启动服务
    优化:nodemon

    1. 配置nodemon

    2. 修改 package.json 中的启动命令

      		{
      		  "name": "node_p",
      		  "version": "1.0.0",
      		  "description": "",
      		  "main": "index.js",
      		  "scripts": {
      		    "start": "nodemon ./2-nodemon.js",
      		    "start:node": "node ./2-nodemon.js",
      		    "test": "echo \"Error: no test specified\" && exit 1"
      		  },
      		  "keywords": [],
      		  "author": "",
      		  "license": "ISC",
      		  "devDependencies": {
      		    "nodemon": "^2.0.15"
      		  }
      		}
      
    3. nodemon.js配置指定修改的文件
      - 配置 指定 特殊watch 的文件

      {
          "watch": [
              "./2-nodemon.js"
          ]
      }
      
    4. 2-nodemon.js

      const http = require('http')
      const server = http.createServer((req, res) => {
          res.statusCode = 200;
          res.setHeader('Content-Type', 'text/plain');
          res.end('hesslsl');
      })
      server.listen(3000, '127.0.0.1', () => {
          //回调
          console.log('server 启动了')
      })
      
  3. nrm和nvm

  • nrm管理源,比如cnpm,在有些库不好下载,可以换源下载
    1. 安装 npm i nrm -g
    2. nrm ls
    3. nrm current
    4. nrm use taobao
    5. nrm add xxx 自定义源
  • nvm
    1. nvm ls remote --lts
    2. nvm install xxx
    3. nvm use xxx
    4. nvm ls
    5. nvm alias default node
    6. nvm -v

web基础

web基础

1. 前端(ajxs,ws,ws)->服务器(web应用)->缓存/数据库
2. express
		1. 接收req,处理res
		2. express:node中的一种web框架
	3. express应用
		1. npm init -y
		2. git init
		3. .gitignore (node_modules)
		4. npm i express -s
		5. src/app.js
		6. 具体代码
		

```
const express = require('express');
//是一个express实例
const app = express();
// app.use((req, res) => {
//     res.json({
//         name: "sss"
//     })
// })
app.get('/name/:age', (req, res) => {
    //res.send('tom get')
    let { age } = req.params;
    res.json({
        name: 'tom',
        age
    })
})
app.post('/name', (req, res) => {
    res.send('tom post')
})
app.listen(3000, () => {
    console.log('server ok')
})
```

路由

  1. 准备
    1. git init
    2. npm init -y
    3. npm i nodemon -D
    4. npm i express -S
    5. package.json 里面添加 "start": "nodemon src/app.js",
    

实战:做一个任务管理项目

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-01-11 23:54:12  更:2022-01-11 23:55:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 23:59:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码