思考:为什么javascript可以在浏览器中被执行
答:因为浏览器中包含有解析器.
不同的浏览器使用不同的javascript解析器
1/chrome 浏览器 =>v8
2/firefox 浏览器 +> odinmonkey(奥丁猴)
3/safri 浏览器 =>jsCode
4/IE浏览器 => Chakra(查克拉)
注意:chrome 浏览器的v8是最好的
思考:为什么javascript可以操作Dom和Bom
答:每个浏览器都内置了Dom,Bom这样的api函数,因此浏览器才可以调用他们
思考:浏览器中javascript运行环境
(1)运行环境指的是代码正常运行所需的必要环境
(2)V8引擎负责解析和执行js代码
(3)内置api是由运行环境提供的特殊接口,只能在所属的运行环境中被调用
node简介
1.什么是node.js
node.js是一个基于chrome V8引擎的javascript运行环境
如何进入 REPL 环境:打开任意终端,直接输入node 命令并回车,就会进入到REPL 环境中;如何离开 REPL 环境:在终端中,按两次Ctrl + C 快捷键,就能退出REPL 环境;
在 Windows 的命令行中,我们可以通过如下快捷键,来提高命令行的操作效率: ① 使用 ↑ 键,可以快速定位到上一次执行的命令 ② 使用 tab 键,能够快速补全路径 ③ 使用 esc 键,能够快速清空当前已输入的命令 ④ powershell,输入 clear命令,可以清空终端。 cmd中要用 cls
终端命令行
1.ls =》 list 查看 ,查看当前文件夹下所有的目录列表 dir => list 查看 ,查看当前文件夹下所有的目录列表 2.cd =》 切换到某个文件夹下, change directory 3.cd ../ =》退回上级文件夹 cd ./ 当前目录 4.md=> 创建一个文件夹 5.rd => 删除一个文件夹 6.e: => 磁盘名: 可以直接将路径变为e: 7.pwd => 当前工作的目录,就是目前在终端操作的哪个目录
1.fs文件系统模块
1.1什么是fs文件系统模块
const fs = reuire('fs')
1.2
fs.readFile(path[, options], callback)
参数1:必选参数,需要指定一个文件路径的字符串,表示要读取哪个路径对应的文件。
参数2:可选参数,表示以什么编码格式来读取文件。
参数3:必选参数,文件读取完成后,通过回调函数拿到读取的结果(err,data)=>{}
const fs = require('fs'); fs.readFile('hello.txt', 'utf-8', (err, data) => { // 判断是否读取成功 if (err) return console.log(err); console.log(data); });
fs.writeFile(file, data[, options], callback)
参数1:必选参数,需要指定一个文件路径的字符串,表示要文件的存放路径。
参数2:必选参数,表示要写入的内容。
参数3:可选参数,表示以什么格式写入文件内容,默认值是utf8。
参数4:必选参数,文件写入完成后的回调函数。
2.
const fs = require('fs'); fs.writeFile('./hello.txt', 'hello node', (err) => { // 判断是否写入成功 if (err) return console.log(err); console.log('写入成功'); });
1.4
使用 fs.readdir() 方法,可以读取指定目录下所有文件的名称,语法格式如下:
fs.readdir(path[, options], callback)
参数1:必选参数,表示要读取哪个目录下的文件名称列表。
参数2:可选参数,以什么格式读取目录下的文件名称,默认值是utf8。
参数3:必选参数,读取完成以后的回调函数。
2.fs.readdir()的示例代码(得到的是一个数组)
通过 fs.readdir() 方法,可以读取指定目录下,所有文件的名称:
const fs = require('fs'); fs.readdir('./', (err, data) => { // 错误处理 if (err) return console.log(err); console.log(data); });
二.path路径模块
2.1 什么是path路径模块
path 模块是 Node.js 官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户对路径的处理 需求。
const path = require('path')
2.2
path.join([...paths])
const path = require('path'); console.log( path.join('a', 'b', 'c') ); // a/b/c console.log( path.join('a', '/b/', 'c') ); // a/b/c console.log( path.join('a', '/b/', 'c', 'index.html') ); // a/b/c/index.html console.log( path.join('a', 'b', '../c', 'index.html') ); // a/c/index.html console.log(__dirname); // node自带的全局变量,表示当前js文件所在的绝对路径 // 拼接成绩.txt的绝对路径 console.log( path.join(__dirname, '成绩.txt') ); // ------ 最常用的
2.3
使用 path.basename() 方法,可以获取路径中的最后一部分,经常通过这个方法获取路径中的文件名
path.basename(path[,ext])
// 找文件名 console.log( path.basename('index.html') ); // index.html console.log( path.basename('a/b/c/index.html') ); // index.html console.log( path.basename('a/b/c/index.html?id=3') ); // index.html?id=3 console.log(path.basename('/api/getbooks')) // getbooks
2.4
使用 path.extname() 方法,可以获取路径中的扩展名部分,语法格式如下:
path.extname(path)
2.
- // 找字符串中,最后一个点及之后的字符 console.log( path.extname('index.html') ); // .html console.log( path.extname('a.b.c.d.html') ); // .html console.log( path.extname('asdfas/asdfa/a.b.c.d.html') ); // .html console.log( path.extname('adf.adsf') ); // .adsf