虽然这段代码可以在浏览器中正常运行,但在 Node.js 中 f1()
会产生一个“找不到变量 x
”的 ReferenceError
。这是因为在 Node 中顶级作用域不是全局作用域,而 x
其实是在当前模块的作用域之中。
js基础巩固(一)
js基本数据类型:
1.Number( Int, Float, NaN, Infinity)
2.String (单引号、双引号包裹的)
3.Boolean(true, false)
4.Object(无序名值对)【引用类型】
5.Null(值为null,表示为空)
6.Undefined(值为undefined,表示a.已声明但未赋值;b.获取对象属性不存在)
typeof VS instanceof
获取数据类型函数: typeof(a) (除了booleam、Number、String、function、undefined等,其余均返回Object)
判断a是否为b的实例: instanceof(可以具体到是Array、Null等)
例如: a instanceof Array ? true : false;
call VS apply VS bind
obj.call(thisObj, a, b) // thisOb继承了Array的属性跟方法(a,b为假设的参数)
obj.apply(thisObj, [a, b]) // apply效果与上相同,只是传参为数组形式
add(5,3); //8
add.call(sub, 5, 3); //8
add.apply(sub, [5, 3]); //8
sub(5, 3); //2 sub.call(add, 5, 3); //2
sub.apply(add, [5, 3]); //2
obj.bind(thisObj, a, b) // thisObj同样继承了Array的属性跟方法,不同之处在于,bind方法不会立即执行
add.bind(sub, 5, 3); //不返回8
add.bind(sub, 5, 3)(); //8
new Function创建函数跟关键字function创建函数的区别
所有的函数都是Function对象,通过new Function创建的函数,即由 Function
构造函数创建的函数不会创建当前环境的闭包,它们总是被创建于全局环境,因此在运行时它们只能访问全局变量和自己的局部变量,不能访问它们被 Function
构造函数创建时所在的作用域的变量。
var x = 10; function createFunction1() { var x = 20; return new Function('return x;'); // 这里的 x 指向最上面全局作用域内的 x } function createFunction2() { var x = 20; function f() { return x; // 这里的 x 指向上方本地作用域内的 x } return f; } var f1 = createFunction1(); console.log(f1()); // 10 var f2 = createFunction2(); console.log(f2()); // 20