您的位置:首页 > Web前端 > JavaScript

JS 闭包问题

2016-02-26 13:52 639 查看
var result = [];
function foo1() {
var i = 0;
for (; i < 3; i = i + 1) {
result[i] = (function (j) {
return function () {
console.log  ("log==111=>" + j);
};
})(i);
}
};
foo1();

result[0]();  //  0
result[1]();  //  1
result[2]();  //  2
//============================================================================================

var result = [];
function foo() {
var i = 0;
for (; i < 3; i = i + 1) {
result[i] = function () {
console.log  ("log===>" + i);
}
}
};
foo();
result[0]();  //  3
result[1]();  //  3
result[2]();  //  3

//============================================================================================

var window = {};//模拟浏览器中的window
window.export = {};

(function () {
var _userId = 23492;
var _typeId = 'item';
var export1 = {};

function converter(userId) {

return +userId;
}

export1.getUserId = function () {
return converter(_userId);
}
export1.
getTypeId = function () {
return _typeId;
}

window.export = export1;
})();

console.log("====>,,,,,," + window.export.getUserId());

//============================================================================================

var a = 10;
(function () {
var b = 20;
})();
console.log(a);    //     10
//console.log(b);    //     error,     b     in     not     defined

for (var item     in     {a: 1, b: 2, c: 3,d:3}) {
console.log(item);
var n=6;
}

console.log(item+n);//没有块级 作用域 所以还能访问的到

eval("var a  =  1;");

//============================================================================================
function outer() {
var i = 1;
//var func = new Function("console.log(typeof m);");//new Function()这样的拿不到上层 的作用域 链 ,而下边这种就能拿到
var func = function () {
console.log(typeof i);
};
func();           //      undefined
}
outer();

//============================================================================================
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  闭包 javascript