学习笔记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

闭包基础

有权访问另一个函数作用域内变量的函数都是闭包
一个函数引用另外一个函数的变量,因为变量被引用着所以不会被回收,一般可以用来封装一个私有变量
例如:

// 构造函数
function IceCream() {
  this.scoops = 0;
}
// 为 IceCream 添加 addScoop 方法
IceCream.prototype.addScoop = function() {
  setTimeout(function() {
    this.scoops++;
    console.log('scoop added!');
  }, 500);
};
const dessert = new IceCream();
dessert.addScoop(); //500毫秒之后,dessert.scoops任为0

使用闭包

// 构造函数
function IceCream() {
  this.scoops = 0;
}
// 为 IceCream 添加 addScoop 方法
IceCream.prototype.addScoop = function() {
  const cone = this; // 设置 `this` 给 `cone`变量
  setTimeout(function() {
    cone.scoops++; // 引用`cone`变量
    console.log('scoop added!');
  }, 500);
};

const dessert = new IceCream();
dessert.addScoop(); //500毫秒之后,dessert.scoops = 1

立即调用函数表达式(IIFE)

定义之后立即被调用的函数
将一个函数包在圆括号中,然后在末尾添加一对圆括号来调用它

(function sayHi(){
    alert('Hi there!');
  })();
    //带参数
(function (x, y){
    console.log(x * y);
  })(2, 3);   // 6

IIFE 的主要用途之一就是创建私有作用域
如果你只想完成某个一次性任务(例如初始化应用程序),那么 IIFE 将是完成任务,同时避免额外变量污染全局环境的好办法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值