2021-10-11 html5 第三阶段 第一天

path模块(路径模块)

        + path.join()

            == 将所有给定的path片段链接在一起

            == 规范化生成的路径

            == 语法: path.join('/目录1','目录2','目录3/目录4')

            == 返回值: '/目录1/目录2/目录3/目录4'

            == 返回值不一定是绝对路径

        + path.resolve()

            == 同path.join()

            == 区别: 会将路径或路径片段的序列解析成绝对路径

url.parse

        == 作用:把URL解析成对象

        == 语法:url.parse(urlString,parseQueryString,slashesDenoteHost)

            == urlString:表示url地址

            == parseQueryString:是一个布尔值,如果为true,会解析查询字符串

            == slashesDenoteHost:是一个布尔值,如果为true,表示//后面,/前面是主机名(完整地址设不设置关系不大)

    url.format

        == 作用:把url对象解析成url地址字符串

        == 语法: url.format(url对象)

        == 返回值: url地址字符串

    url.resolve

        == 作用: 把两端url片段,组合成一个完整的url

        == 返回值: url地址字符串

querystring模块

        == 对查询字符粗执行更加强大的解析

    querystring.stringify()

        == 作用:把对象变成查询字符串

        == 语法: querystring.stringify(要转换的对象[,自定义分隔符,自定义键值对之间的链接符])

            == 默认是用&作为分隔符,键值用=链接

            == 返回值:查询字符串

    querystring.parse()

        == querystring.stringify的逆方法

        == 语法:querystring.parse('查询字符串'[,自定义分隔符,自定义键值对之间的链接符])

        == 返回值:对象

    querystring.escape()

        == 把字符串进行url编码

    querystring.unescape()

        == 对url进行解码

import * as fs from "fs";

// 获取文件信息

fs.stat('./07fs_stat.mjs',function(err,stats){

    // 获取完成文件信息以后执行

    if(!err){

        console.log(stats)

        console.log(stats.isFile());//判断是否是一个文件

        console.log(stats.isDirectory());//判断是否是一个文件夹

    }

})

const fs = require('fs');

fs.mkdir('abc',function(err){

    // 当文件夹创建完成以后执行这个函数

    if(!err){

        console.log('目录创建成功')

    }

})

const fs = require('fs');

// 写入的文件路径

const filePath = "logs/d.txt";

const text = "写入文件的内容\n";

// 异步 覆写

// fs.writeFile(filePath,text,function(err){

//    if(!err){

//        console.log('文件写入成功')

//    }

// })

// 异步 追加写入文件

fs.appendFile(filePath,text,function(err){

    if(!err){

        console.log('文件写入成功')

    }

})

const fs = require('fs');

const filePath = "logs/d.txt";

// 第一种写法

fs.readFile(filePath,(err,data)=>{

    // 当文件读取完成执行该函数

    if(!err){

        console.log(data.toString())

    }

})

// 第二种写法

fs.readFile(filePath,'utf-8',(err,data)=>{

    if(!err){

        console.log(data)

    }

})

// 读取文件目录

fs.readdir('logs',(err,files)=>{

    if(!err){

        console.log(files)

    }

})

const filePath = "logs/d.txt";

const newPath = 'logs/great.txt';

fs.rename(filePath,newPath,(err)=>{

    if(!err){

        console.log('文件名修改成功')

    }

})

// 不仅可以修改文件名

// 还可以修改文件夹的名字

// 导入events模块

const EventEmitter = require('events');

// 创建一个事件触发器

const myEvent = new EventEmitter();

// 定义事件监听器

myEvent.on('many',(data)=>{

    console.log('many事件发生了')

    console.log(data)

})

myEvent.once('one',()=>{

    console.log('one事件发生了')

})

// 触发事件?传递事件参数?

myEvent.emit('many')

myEvent.emit('many',{name:'zhangsan'})

myEvent.emit('many',123)

myEvent.emit('one')

myEvent.emit('one')

myEvent.emit('one')

http模块/https模块

        + http.request()

            == 第一步:书写请求行和请求头

                + 方式一: var req = http.request(url,callback)

                + 方式二: var req = http.request(options,callback)

            == 第二步:书写请求主体

                + req.write()

            == 第三步:结束请求

                + req.end()

        + http.get()

            == 语法:同http.request()

            == 区别

                == 不用设置method,是get请求

                == 不用书写req.write() ,get请求没有请求主体

                == 不用调用req.end() ,会自动调用

        + http.createServer()

            == 作用:开启服务器,二阶段讲过

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,755评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,305评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,138评论 0 355
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,791评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,794评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,631评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,362评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,264评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,724评论 1 315
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,900评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,040评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,742评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,364评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,944评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,060评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,247评论 3 371
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,979评论 2 355

推荐阅读更多精彩内容

  • 1 服务器创建 创建服务器利用require引入http模块:var http=require("http")利用...
    果木山阅读 323评论 0 1
  • 客 户端的JavaScript是怎样的 什么是JavaScript? +是一个脚本语言 运行在浏览器(浏览器...
    hcySam阅读 388评论 0 2
  • cmd命令: ./ 当前目录 ../ 上一级 dir 查看当前目录 ls 查看当前目录下文件 win...
    3hours阅读 548评论 0 1
  • 首先声明:这个是我边看边写的,所以会有很多不足之处以及错误之处,如果真的有人看到,还请海涵,也可以给我留言讲解一下...
    城门小胡同阅读 242评论 0 0
  • 深入浅出Nodejs 模块机制 Commonjs规范 node的模块实现步骤:路径分析文件定位编译执行核心模块在n...
    lmmy123阅读 424评论 0 1