toString()方法返回一个字符串
为函数的源码。
对于原生的函数:
Math.sqrt.toString()
// "function sqrt() { [native code] }"
函数内部的注释也可以返回,利用这一点实现多行字符串:
var multiline = function (fn) {
var arr = fn.toString().split('\n');
return arr.slice(1, arr.length - 1).join('\n');
};
function f() {/*
这是一个
多行注释
*/}
multiline(f);
// " 这是一个
// 多行注释"
函数和变量作用域只与其声明时所在的作用域有关,与其运行时所在的作用域无关。
var a = 1;
var x = function () {
console.log(a);
};
function f() {
var a = 2;
x();
}
f() // 1
函数的length属性与实际传入的参数个数无关,只反映函数预期传入的参数个数
arguments对象:
由于 JavaScript 允许函数有不定数目的参数,所以需要一种机制,可以在函数体内部读取所有参数。这就是arguments对象的由来。
这个对象只有在函数体内部,才可以使用。
一般情况下可以影响到参数取值,严格模式下不能。
用arguments.length判断带几个参数。
arguments是一个对象,如果要用数组方法要把他转换成数组
var args = [];
for (var i = 0; i < arguments.length; i++) {
args.push(arguments[i]);
}
arguments对象带有一个callee属性,返回它所对应的原函数,在严格模式下禁用
立即执行函数可以避免全局变量污染
eval命令接受一个字符串作为参数,并将这个字符串当作语句执行。
eval('var a = 1;');
a // 1
如果eval的参数不是字符串,那么会原样返回;
eval没有自己的作用域,都在当前作用域内执行,因此可能会修改当前作用域的变量的值,造成安全问题。
如果使用严格模式,eval内部声明的变量,不会影响到外部作用域。但是依旧可以读写当前作用域
(function f() {
'use strict';
eval('var foo = 123');
console.log(foo); // ReferenceError: foo is not defined
})()
(function f() {
'use strict';
var foo = 1;
eval('foo = 2');
console.log(foo); // 2
})()
eval别名调用:因为js引擎分辨不出来,所以别名调用都是都是全局作用域。