Node.js基础知识

本文介绍了Node.js的基础知识,包括Node.js的概念、安装方法、CommonJS模块化及其与ES6模块的区别,以及Node.js如何处理HTTP请求,讲解了req和res、路由定义、querystring的使用和解析,并探讨了获取request body的方法。
摘要由CSDN通过智能技术生成

Node.js基础知识

结合学习视频整理了一些关于node.js的一些基础知识

 

 


前言

本文会介绍Node.js的基础入门知识(什么是Node.js,如何安装Node.js;如何使用commonjs模块化,commonjs和es6 module模块化有什么区别,为什么要使用模块化;Node.js和js有什么主要区别),Node.js如何处理HTTP(req和res是什么;如何定义路由;querystring是什么;res如何返回数据;如何获取req body)


提示:以下是本篇文章正文内容,下面案例可供参考

一、Node.js基础知识

1.什么是Node.js

下图是node.js官网上面给出的定义。V8 是 Chrome 的js引擎,node.js是基于js语法的,所以也可以借用 V8 引擎。运行时:代码运行环境,有了运行时代码才能被执行。

Node.js是一个基于Chrome V8 引擎的 JavaScript 运行时

2.如何安装Node.js

进入官网,根据提示下载即可。

点击下载,选择需要的安装包

3.commonjs模块化

  • 什么是模块化,为什么要使用commonjs模块化?

模块化就是将一整段冗余的代码拆分成一个个独立的模块,再将独立的模块引入到主文件里。在书写一个大型项目时,如果把代码写到一个文件里面就会造成代码的冗余。这时我们就需要使用模块化,将独立的代码拆分出去,使代码看起来更简洁,也便于维护。

  • 如何使用commonjs模块化?

使用module.exports进行导出

使用require进行导入
  • commonjs和es6 module 的区别

commonjs是动态的,es6 module是静态的。es6 module只能出现在顶级目录下。

4.Node.js和js的区别

它们都使用了js语法,但使用的API不同:node.js使用的是nodejs的API(处理http,文件操作。在nodejs 环境下可以使用),js 使用的是web API(前端网页的dom bom 事件等,在浏览器环境下使用)。

二、Node.js如何处理HTTP

1.req和res

req是request的简称,服务器获取用户的请求。res是response的简称,服务器返回的响应数据

const http = require('http')

const server = http.createServer((req, res) => {
    const url = req.url
    console.log(url);
    res.end('已收到请求')
})
server.listen(3000)
console.log('http请求已被监听 3000 端口');

2.如何定义路由

路由包含:定义method、定义url规则、定义输入(request body)和输出(response body)格式。

const http = require('http')
const querystring = require('querystring')

const server = http.createServer((req, res) => {
    const url = req.url
    const path = url.split('?')[0]
    const method = req.method

    // 定义路由:模拟获取留言板列表
    if (path === '/api/list' && method === 'GET') {
         res.end('this is list router')
    }
    // 定义路由:模拟创建留言
    if (path === '/api/create' && method === 'POST') {
        res.end('this is create router')
    }
})
server.listen(3000)

 

3.querystring

  • 什么是querystring

url问号?后面的都是querystring(也叫url参数),&符号分隔,key=value形式

http://xxx.com/list.html?keyword=123&lang=en&a=10

  • 如何利用querystring实现动态网页

服务器拿到querystring

根据不同的querystring,返回不同的内容

变化querystring,就变化内容(只要服务端支持)

const http = require('http')
const querystring = require('querystring')

const server = http.createServer((req, res) => {
    const url = req.url
    const path = url.split('?')[0]
    const queryStr = url.split('?')[1]
    const method = req.method

    const query = querystring.parse(queryStr || '')
    console.log('query is', query);
    // 定义路由:模拟获取留言板列表
    if (path === '/api/list' && method === 'GET') {
        if (query.filterType === "1") {
            res.end('this is list router, all')
        }
        if (query.filterType === "2") {
            res.end('this is list router, only mine')
        }
        // res.end('this is list router')
    }
    // 定义路由:模拟创建留言
    if (path === '/api/create' && method === 'POST') {
        res.end('this is create router')
    }
})
server.listen(3000)

 

  • 解析querystring(querystring的底层原理)

// 解析querystring
     const query = {}
     queryStr && queryStr.split('&').forEach(item => {
         const key = item.split('=')[0]
         const val = item.split('=')[1]
         query[key] = val
     })

 

4.res如何获取数据

通过res的一些api方法来获取数据。

res.writeHead(200, { 'Content-type': 'application/json'})   //设置请求头信息

res.end(JSON.stringify(result))   //设置请求体信息

 

5.如何获取request body 数据

// 定义路由:模拟创建留言
    if (path === '/api/create' && method === 'POST') {

        const reqType = req.headers['content-type']
        let bodyStr = ''
        req.on('data', chunk => { //服务端怎么识别“流” 并接受数据  chunk 即“流”的每一段数据
            bodyStr += chunk.toString()
        })
        req.on('end', () => { //服务端怎么知道流完了
            if (reqType === 'application/json') {
                const body = JSON.parse(bodyStr)
                console.log('body is: ', body);
            }

            res.end('接受完成')
        })
        return
    }

总结

以上就是我在学习node.js中总结的一些知识,可能有不是很正确的地方,如果有朋友看出问题的话,希望能够指明,大家互相学习,共同进步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值