js学习笔记01-函数,作用域,闭包
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js学习笔记01-函数,作用域,闭包相关的知识,希望对你有一定的参考价值。
${var}
//变量的占位符, ${}里边 依旧是js,字符串拼接
var str1 = "Hello";
var str2 = "World";
console.log("say: "+str1+" "+str2+"!");
console.log(`say: ${str1} ${str2}!`);
函数function
像处理(字符串、数组或数字)一样来处理函数
1)存储在变量中。
2)从一个函数返回。
3)作为参数传递给另一个函数
回调函数
接受其他函数作为参数(和/或返回函数,如上一部分所述)的函数被称为高阶函数。作为参数传递给另一个函数的函数被称为回调函数。
数组方法 forEach()遍历数组,map获取数组中元素的详情,filter筛选
forEach()
数组的 forEach() 方法接受一个回调函数,并为数组中的每个元素调用该函数。换句话说,forEach() 让你可以迭代(即遍历)一个数组,类似于使用 for 循环
[1, 5, 2, 4, 6, 3].forEach(function logIfOdd(n) {
if (n % 2 !== 0) {
console.log(n);
}
});
// 1
//5
//3
function logIfOdd(n) {
if (n % 2 !== 0) {
console.log(n);
}
}
[1, 5, 2, 4, 6, 3].forEach(logIfOdd);
map()
map() 不同于forEach(),会根据回调函数所返回的内容返回一个新的数组。
map() 方法返回一个新的数组,而不会修改原始数组。
var arrayName = ["fish","sugarbeans","theredhands"];
var arrayNameLength = arrayName.map(function(name){
return name.length;
})
console.log(arrayNameLength);
//[4,10,11]
filter 过滤器
数组的 filter() 方法与 map() 方法类似,
var arrayNewName = arrayName.filter(function(name){
return name.length>6;
})
console.log(arrayNewName);
作用域
函数的作用域包括:
1)该函数的参数。
2)该函数内部声明的局部变量。
3)来自其父函数作用域的变量。
4)全局变量。
在访问变量时,javascript 引擎将遍历作用域链,首先查看最内层(例如函数的局部变量),然后查看外层作用域,最后在必要时到达全局作用域。
变量阴影
当你所创建的变量与作用域链中的另一个变量具有相同名称时
JavaScript 不会弹出错误消息或阻止你创建这样一个变量。实际上,局部作用域的变量只会暂时“遮蔽”外部作用域中的变量。这被称为变量阴影。
let n = 2;
function myFunction() {
let n = 8;
console.log(n);
}
myFunction();
// 8
闭包
闭包--函数和该函数声明位置的词法环境的组合
1)每次定义函数时,都会为该函数创建闭包
2)函数会保持对其父作用域的引用, 如果仍可访问该函数的引用,作用域就会保持不变
3)闭包类似java私有属性的机制
function count() {
var arr = [];
for (var i=1; i<=3; i++) {
arr.push(function () {
return i * i;
});
}
return arr;
}
var results = count();
var f1 = results[0]; //()=>16
var f2 = results[1]; //()=>16
var f3 = results[2]; //()16
立即调用函数表达式(IIFE)
定义之后立即被调用的函数
将一个函数包在圆括号中,然后在末尾添加一对圆括号来调用它
(function sayHi(){
alert(‘Hi there!‘);
})();
//带参数
(function (x, y){
console.log(x * y);
})(2, 3); // 6
IIFE 的主要用途之一就是创建私有作用域
如果你只想完成某个一次性任务(例如初始化应用程序),那么 IIFE 将是完成任务,同时避免额外变量污染全局环境的好办法
以上是关于js学习笔记01-函数,作用域,闭包的主要内容,如果未能解决你的问题,请参考以下文章
JS你不知道的JavaScript 笔记—— 作用域与闭包 - 编译原理 - LHS - RHS - 循环与闭包 - 模块 - 词法作用域 - 动态作用域