算法刷题
大厂面试还是很注重算法题的,尤其是字节跳动,算法是问的比较多的,关于算法,推荐《LeetCode》和《算法的乐趣》,这两本我也有电子版,字节跳动、阿里、美团等大厂面试题(含答案+解析)、学习笔记、Xmind思维导图均可以分享给大家学习。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
写在最后
最后,对所以做Java的朋友提几点建议,也是我的个人心得:
-
疯狂编程
-
学习效果可视化
-
写博客
-
阅读优秀代码
-
心态调整
4、 node 自动进入上一级目录 重复上面的步骤
node 中的包模块查找机制非常类似于 JavaScript 中的 作用域链 和 原型链
5、 如果直到 当前文件模块所属的盘符根路径还找不到,最后报错。
总结: 先去缓存中找,缓存没有如果是核心模块就去读自己的核心模块,如果不是按照路径找,路径没有不是文件的话就是包,就去找这个包
文件定位
文件扩展名分析:按照 `.js` `.json` `.node` 的次序补足扩展名
目录分析和包
模块编译
`.js` 文件,通过 fs 模块同步读取文件后编译执行
`.node` 文件
`.json` 文件,通过 fs 模块同步读取文件后使用 `JSON.parse()` 解析返回结果
其它扩展名,被当作 `.js` 文件载入
兼容模块规范
在代码中加入这些判断
if (typeof exports !== ‘undefined’) {
if (typeof module !== ‘undefined’ && module.exports) {
exports = module.exports = _;
}
exports._ = _;
} else {
// 向 Window 暴露接口对象
root._ = _;
}
兼容AMD模块规范
// 判断在全局是否有 define 这个方法,同步 define 有一个属性叫做 amd
// 两个判定条件都成功,就意味着当前浏览器环境引入了 require.js 文件
if (typeof define === ‘function’ && define.amd) {
define(‘underscore’, [], function() {
return _;
});
}
兼容CMD规范
if (typeof define === ‘function’ && define.cmd) {
define(function (require, exports, module) {
module.exports = _;
});
}
node对象
3、Node 中的 JavaScript
REPL (Read Eval Print Loop:交互式解释器) 运行环境 : 可以执行一些js代码
ECMAScript
nodeJS对象
全局对象
global : 相当于浏览器中的window,不建议使用容易造成冲突
Console : 日志打印和浏览器中的console功能相同,(火狐浏览器给JS加的,用于调试,不在规范中)
process : 进程对象, 获取系统相关的信息
Buffer(class): 全局构造函数,用来操作二进制数据
全局函数
setInterval 和 clearInterval
setTimeout 和 clearTimeout
setImmediate 和 clearImmediate
模块内成员
变量:
__dirnam :获取当前文件绝对路径(不包括文件名)
__filename: 获取当前文件的绝对路径(包括文件名)
方法:
require (‘路径’) : 获取模块的方法
exports:
exports= module.exports
exports是引用 module.exports的值,而模块导出的时候,真正导出的执行是 module.exports,而不是exports
module.exports和exports的区别就是var a={}; var b=a; 中a和的区别。exports指向的只是一个引用。改变exports的指向后所添加的exports.***都是无效的。因为require返回的只是module.exports. 所以不能在使用了exports.***之后,改变module.exports的指向。因为exports.***添加的属性和方法并不存在与module.exports所指向的新对象中。
个人建议,可以全部使用module.exports来应对所有的情况,并尽量减少犯错的机会。
module
module对象
Node内部提供一个Module构造函数,所有模块都是Module的实例 • 每个模块内部,都有一个module对象,代表当前模块。
– module.id 带有绝对路径的模块文件名
– module.filename 模块的文件名,带有绝对路径
– module.loaded 表示模块是否已经完成加载
– module.parent 返回一个对象,表示调用该模块的模块。
– module.children 返回一个数组,表示该模块要用到的其 他模块。
– module.exports 模块对外输出的值(暴露模块方法和属性)
module.exports属性表示当前模块对外输出的接口, 其它文件加载该模块,实际上就是读取 module.exports属性 • 点儿导出单个函数、对象或者值的时候非常有用
为了方便,Node为每个模块提供一个exports变量, 指向module.exports。 相当于在每个模块头部,有这样一行命令: var exports = module.exports;
结果就是: – 在对外输出模块接口时,可以向exports对象添加方法
及可以直接使用exports代替module.exports
注意:不能直接给exports赋值,因为这样等于切断了 exports和module.exports的联系
模块加载
require()加载模块
• 在Node.js中,require命令用于加载模块文件
• 基本功能: 1、读取并执行一个JavaScript文件 2、 然后返回该模块的exports对象 3、 如果没有发现指定模块,会报错
require模块加载规则:
• 参数字符串以 “/”开头 (绝对路径)
• 参数字符换以“./”开头 (相对路径)
• 参数字符串没有路径,表示加载核心模块, 或者一个位于各级node_modules目录已安装的模块
• 参数字符串可以省略后缀名 : .js、.json、.node
– .js会当做JavaScript脚本文件解析
– .json会以JSON格式解析
– .node会以编译后的二进制文件解析
注意: node项目目录结构没有要求, 相对路径是相对于node命令所在的目录
核心模块与文件模块
• 核心模块 :require(‘核心模块名’)
• 文件模块 : require(‘路径+模块名’)路径包括相对路径与绝对路径 ,绝对路径的加载速度快
总结
– 加载模块时将运行模块文件中的每一行代码
– 相同模块多次引用不会引起模块内代码多次执行
核心模块:
http : 提供http服务器功能
url :解析url
fs :与文件系统交互
querystring :解析url查询字符串
util :提供一系列实用小工具
path : 处理文件路径
核心模块的源码都在node的lib子目录中。为了提高运行效率,她们安装的时候都会被编译成二进制文件
模块的加载机制:
如果require绝对路径的文件,查找时不会去遍历每一个node_modules目录,其速度最快。 其余流程如下:
1. 从module path数组中取出第一个目录作为查找基准。
2. 直接从目录中查找该文件,如果存在,则结束查找。如果不存在,则进行下一条查找。
3. 尝试添加.js、.json、.node后缀后查找,如果存在文件,则结束查找。如果不存在, 则进行下一条。
4. 尝试将require的参数作为一个包来进行查找,读取目录下的package.json文件,取得 main参数指定的文件。
5. 尝试查找该文件,如果存在,则结束查找。如果不存在,则进行第3条查找。
6. 如果继续失败,则取出module path数组中的下一个目录作为基准查找,循环第1至5个 步骤。
7. 如果继续失败,循环第1至6个步骤,直到module path中的最后一个值。
8. 如果仍然失败,则抛出异常。
总结
所有代码都运行在模块作用域,不会污染全局作用域
模块可以多次加载,但是只会在第一次加载的时候运行 一次,然后运行结果就被缓存了,以后再加载,就直接 读取缓存结果
模块的加载顺序,按照代码的出现的顺序是同步加载的
require是同步加载模块的
路径操作模块:`path`
`path` 是一个核心模块,在使用的时候必须加载。
basename(p[,ext]) 注意第二个参数用法 获取文件名
dirname§ 获取文件目录
extname§ 获取文件扩展名
isAbsolute(path) 判断是否是绝对路径
join([path1][,path2][,…]) 拼接路径字符串
sep 获取操作系统的文件路径分隔符
文件操作模块:‘fs’
`fs` 是一个核心模块,在使用的时候必须加载。
同步和异步文件系统调用
异步:
fs.readFile(‘./README.md’, function (err, data) {
if (err) {
throw err
}
console.log(data.toString())
})
err 就表示操作的过程中可能出错的对象
data 就是最终的执行结果
IO 需要时间,例如有 1MB 的文件 和 100MB 的文件
异步IO 不会阻塞后续代码的继续执行
一般一个异步IO往往都需要一个回调函数来接收处理结果
而 回调函数中一般第一个参数都是 err 对象,表示可能出错的对象
第二个参数才是真正的数据
异步捕获不了异常,处理异步代码中的异常
异步IO,如果出错,node 不会帮你自动抛出异常
对于异步IO,try-catch 是无法捕获异常的
如果想要捕获异常,只能通过回调函数中的参数 err 来判断进行捕获
所以 err 一定要进行判断,否则代码不健壮
同步:
try {
文末
js前端的重头戏,值得花大部分时间学习。
推荐通过书籍学习,《 JavaScript 高级程序设计(第 4 版)》你值得拥有。整本书内容质量都很高,尤其是前十章语言基础部分,建议多读几遍。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
另外,大推一个网上教程 现代 JavaScript 教程 ,文章深入浅出,很容易理解,上面的内容几乎都是重点,而且充分发挥了网上教程的时效性和资料链接。
学习资料在精不在多,二者结合,定能构建你的 JavaScript 知识体系。
面试本质也是考试,面试题就起到很好的考纲作用。想要取得优秀的面试成绩,刷面试题是必须的,除非你样样精通。
这是288页的前端面试题