Node.js sistema modular

Node.js sistema modular introducido

  • Para hacer el archivo Node.js puede llamar a los demás, Node.js ofrece un sencillo 模块系统. módulo de Node.js es el componente básico de la aplicación y el archivo del módulo es uno a uno. En otras palabras, 一个 Node.js 文件就是一个模块este documento puede ser el código JavaScript, extensiones compilados en C / C ++ o JSON.
  • Módulo se divide en tres categorías
    • 内置模块 Viene con el módulo de entorno de nodos de instalación
    • 自定义模块 Escribir nuestros propios módulos
    • 第三方模块 Otros módulo escrito, en la web para su descarga y uso este artículo no se introducirá
  • Use módulos son los primeros en importar un módulo, entonces este módulo a una variable que contiene todo el contenido de un módulo
'定义'var/let/const '变量'=require(' 模块名 ')
  • En este artículo no somos node + 文件名la forma de ejecutar un archivo, pero el uso nodemon + 文件名de cambios en los archivos de monitor en tiempo real, ya que node + 文件名cada cambio de archivo necesita para funcionar una vez más.
    • nodemoninstalaciónnpm install nodemon -g

Módulo incorporado

A, fs módulo

//引入fs模块
const fs = require('fs')
1. Leer archivo

Aquí Insertar imagen Descripción

  • lectura asíncrona
// 文件读取
// fs.readFile('地址',回调函数)  异步读取   必须写回调函数
fs.readFile("./html/index.html",(err,data)=>{
    console.log("err",err)    //如果文件读取成功,err就是null
    console.log("data",data)  //data就是读取后的文件内容
})

Aquí Insertar imagen Descripción

  • lectura sincrónica
// fs.readFileSync   同步读取  
let data = fs.readFileSync("./html/index.html")
console.log("data",data)  

! [Descripción Insertar imagen aquí] (https://img-blog.csdnimg.cn/20200309224936582.png)

  • Escribir formato de codificación, leer caracteres chinos
fs.readFile("./html/index.html","utf-8",(err,data)=>{
    console.log("err",err)    //如果文件读取成功,err就是null
    console.log("data",data)  //data就是读取后的文件内容
})

Aquí Insertar imagen Descripción

2. Cambie el nombre del archivo
//异步  改名  必须有回调函数
//fs.rename('改前','改后',err=>{})
//同步 改名
//fs.renameSync("改前","改后")

fs.renameSync("./html/index.html","./html/about.html")
3. Eliminar archivos
//fs.unlinkSync('文件路径')
//同步
fs.unlinkSync("./html/index.html") 
//异步 
fs.unlink("./html/about.html",err=>{})  
4. Eliminar el directorio de archivos
//fs.rmdir('文件路径')
//同步
fs.rmdirSync("./html/index.html")  
//异步
fs.rmdir("./html/about.html",err=>{})  

Dos, http módulo

  • código del módulo
  • Creación de un servidor Web
//1.引入http模块
const http = require("http")

//2.创建http服务对象
//http.createServer(回调函数)
const app = http.createServer((req,res)=>{
    console.log("前端访问我了...")

    //后端需要设置响应头  
    res.writeHead(200,{"Content-Type":"text/html;charset=utf-8"})//需要配置响应头才能够显示中文  不然会发生乱码
    
    
    // res.write("你好!")
    res.write(`<!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        你好呀!大兄弟
    </body>
    </html>`)//可以用模板字符串  传递元素

    res.end() //后端需要结束响应  必须要填写  如果不填写  页面会一直加载
})

//3.监听端口
app.listen(8000,"localhost",()=>{
    console.log("server in running....")
})

  • Abra el navegador
    Aquí Insertar imagen Descripción
  • cabecera Conjunto de respuestasres.writeHead(200,{"Content-Type":"text/html;charset=utf-8"})
    Aquí Insertar imagen Descripción

Tres, módulo de url

//引入url模块
const url = require("url")
1. url.parse(str,true)Devuelve verdadero objeto se añade a la meta de procesamiento de consultas
str -> obj  返回 对象  true 
Url{
		protocol: 'http:',	协议
		slashes: true,	双斜杠
		auth: null,   作者
		host: 'localhost:8002',  主机
		port: '8002',	端口
		hostname: 'localhost',  baidu
		hash: '#title',	哈希(锚)
		search: '?username=sdfsdf&content=234234',	查询字符串
		query: 'username=sdfsdf&content=234234',	数据
		pathname: '/aaa',	文件路径
		path: '/aaa?username=sdfsdf&content=234234',	文件路径
		href: 'http://localhost:8002/aaa?username=sdfsdf&content=234234#title'
		}
  • No llene verdadera url.parse(str)
let str = "http://www.baidu.com:80/app/html/index.html?a=1&b=2#title" 
let obj = url.parse(str)
console.log(obj)

Aquí Insertar imagen Descripción

  • llenar verdadera url.parse(str,true)
let str = "http://www.baidu.com:80/app/html/index.html?a=1&b=2#title" 
let obj = url.parse(str,true)
console.log(obj)

Aquí Insertar imagen Descripción

2. url.format(obj)Devuelve una serie de
const url = require("url")
let str = "http://www.baidu.com:80/app/html/index.html?a=1&b=2#title" 
let obj = url.parse(str,true)
console.log(url.format(obj))

Aquí Insertar imagen Descripción

Cuatro, módulo de cadena de consulta

  • El procesamiento de la cadena de consulta, tales como :? clave = valor y clave2 = valor2
  • querystring.parse(str) Devuelve el objeto
  • querystring.stringify(obj) Devuelve una cadena
const querystring = require("querystring")

let str = "a=1&b=2&c=3"

//str => obj
console.log(querystring.parse(str))


//obj => str
console.log(querystring.stringify({a:1,b:2}))

Aquí Insertar imagen Descripción

módulos personalizados

  • Escribir un archivo js, ​​que se convierta en un módulo personalizado
  • En otra referencia de archivos js
// 这个文件就是一个我自己创建的自定义模块

// 可以在  自定义模块中  写一些方法
function fn1() {
  console.log('我是 a 模块里面的 fn1 方法')
}

function fn2() {
  console.log('我是 a 模块里面的 fn2 方法')
}


// 要把模块里面的方法导出
// 别的文件再导入 a.js 文件的时候才能得到 a 模块里面的方法
/*
  每一个 js 文件都是一个独立的模块
    + 每一个 js 文件里面天生自带一个变量叫做 module, 是一个对象
    + 每一个 module 里面有一个成员叫做 exports, 是一个对象
    + 这个 module.exports 就是这个文件向外导出的内容
    + 我们把想要向外暴露的内容添加再找个对象里面就可以了
*/

module.exports.fn1 = fn1
module.exports.fn2 = fn2

/*
  相当于再找个文件向外导出了一个对象
  {
    fn1: function fn1() {}
    fn2: function fn2() {}
  }
  谁导入 a.js 文件的时候, 谁就得到了这个对象
*/


// 我是一个 b.js 文件

// 我要导入 a.js 文件
// 我这个变量 a 得到的就是 a.js 文件里面导出的内容
const a = require('./a.js')

// 就可以使用 a 模块导出的方法了
a.fn1()
a.fn2()

Aquí Insertar imagen Descripción

Aprender a ver los documentos en el sitio web oficial

Entrar en la web oficial de Node.js o red Node.js china para ver el documento de aprendizaje

Aquí Insertar imagen Descripción
Aquí Insertar imagen Descripción

Aquí Insertar imagen Descripción

  • Soportes de [ ]contenido se puede omitir
    Aquí Insertar imagen Descripción
Publicado 12 artículos originales · ganado elogios 74 · vistas 7663

Supongo que te gusta

Origin blog.csdn.net/k464746/article/details/104758466
Recomendado
Clasificación