1、为什么用Nodejs,它有哪些优缺点?
优点:
事件驱动,通过闭包很容易实现客户端的生命活期。
不用担心多线程,锁,并行计算的问题
V8引擎速度非常快
对于游戏来说,写一遍游戏逻辑代码,前端后端通用
缺点:
nodejs更新很快,可能会出现版本兼容
nodejs还不算成熟,还没有大制作
nodejs不像其他的服务器,对于不同的链接,不支持进程和线程操作
2、什么是错误优先的回调函数?
错误优先(Error-first)的回调函数(Error-First Callback)用于同时返回错误和数据。
第一个参数返回错误,并且验证它是否出错;其他参数返回数据。
fs.readFile(filePath, function(err, data)
{
if (err)
{
// 处理错误
return console.log(err);
}
console.log(data);
});
3、使用NPM有哪些好处?
通过NPM,你可以安装和管理项目的依赖,
并且能够指明依赖项的具体版本号。
对于Node应用开发而言,
你可以通过package.json文件来管理项目信息,
配置脚本,以及指明依赖的具体版本
4、在JavaScript源文件的开头包含 use strict 有什么意义和好处?
对于这个问题,
既简要又最重要的答案是,
use strict 是一种在JavaScript代码运行时自动实行更严格解析和错误处理的方法。
那些被忽略或默默失败了的代码错误,会产生错误或抛出异常。
通常而言,这是一个很好的做法。
严格模式的一些主要优点包括:
使调试更加容易。
那些被忽略或默默失败了的代码错误,会产生错误或抛出异常,
因此尽早提醒你代码中的问题,
你才能更快地指引到它们的源代码。
防止意外的全局变量。
如果没有严格模式,
将值分配给一个未声明的变量会自动创建该名称的全局变量。
这是JavaScript中最常见的错误之一。
在严格模式下,这样做的话会抛出错误。
消除 this 强制。
如果没有严格模式,
引用null或未定义的值到 this 值会自动强制到全局变量。
这可能会导致许多令人头痛的问题和让人恨不得拔自己头发的bug。
在严格模式下,
引用 null或未定义的 this 值会抛出错误。
不允许重复的属性名称或参数值。
当检测到对象
(例如,var object = {foo: "bar", foo: "baz"};)
中重复命名的属性,或检测到函数中
(例如,function foo(val1, val2, val1){})重复命名的参数时,
严格模式会抛出错误,
因此捕捉几乎可以肯定是代码中的bug可以避免浪费大量的跟踪时间。
使eval() 更安全。
在严格模式和非严格模式下,eval() 的行为方式有所不同。
最显而易见的是,在严格模式下,
变量和声明在 eval() 语句内部的函数不会在包含范围内创建
(它们会在非严格模式下的包含范围中被创建,这也是一个常见的问题源)。
在 delete使用无效时抛出错误。
delete操作符(用于从对象中删除属性)不能用在对象不可配置的属性上。
当试图删除一个不可配置的属性时,
非严格代码将默默地失败,
而严格模式将在这样的情况下抛出异常。
5、JavaScript中的“闭包”是什么?请举一个例子?
闭包是一个可以访问外部(封闭)函数作用域链中的变量的内部函数。
闭包可以访问三种范围中的变量:
这三个范围具体为:
(1)自己范围内的变量,
(2)封闭函数范围内的变量,以及
(3)全局变量。
下面是一个简单的例子:
var globalVar = "xyz";
(function outerFunc(outerArg) {
var outerVar = 'a';
(function innerFunc(innerArg) {
var innerVar = 'b';
console.log(
"outerArg = " + outerArg + "
" +
"innerArg = " + innerArg + "
" +
"outerVar = " + outerVar + "
" +
"innerVar = " + innerVar + "
" +
"globalVar = " + globalVar);
})(456);
})(123);
在上面的例子中,来自于 innerFunc,
outerFunc和全局命名空间的变量都在 innerFunc的范围内。
因此,上面的代码将输出如下:
outerArg = 123
innerArg = 456
outerVar = a
innerVar = b
globalVar = xyz