一、学习内容
函数的应用场景和this的指向问题
// 1.全局中创建和使用函数 - this指向是window
function fn() {
console.log('fn')
console.log(this)
}
window.fn()
// 2.事件中的函数 - this指向了事件的触发者
const btn = document.querySelector('button')
btn.onclick = function () {
console.log('btn')
console.log(this)
}
// 3.定时器中的函数 - this指向了window
setInterval(function () {
console.log('定时器')
console.log(this)
}, 2000)
// 4.构造函数 - this指向了实例化对象
function Person(age) {
this.age = age
}
Person.prototype.sayAge = function () {
console.log(this.age)
}
const p1 = new Person(18)
p1.sayAge()
console.log(p1)
// 5.箭头函数 - this没有指向的。它的this就是父级的this
// 6.IIFE(立即执行函数)
; (function () {
console.log(this)
})();
(function () {
console.log(this)
}());
1.严格模式的概念 在ECMAScript5标准中,JavaScript提出了严格模式的概念 严格模式是一种具有限制性的Javascript模式,从而使代码隐式脱离了“懒散模式” 支持严格模式的浏览器在检测到代码中有严格模式时,会以更加严格的方式对代码进行检测和执行 严格模式对正常模式的JavaScript语义进行了一些限制: 严格模式通过抛出错误来消除一些原有的静默(slient)错误; 严格模式让js引擎在执行代码的时候可以进行更多的优化(不需要对一些特殊的语法进行处理); 严格模式禁用了在ECMAScript未来版本中可能会定义的一些语法。 开启严格模式:更加规范的书写js代码 1.全局的严格模式 “use strict”; 2.立即执行函数中开启严格模式 (function () { “use strict” })(); 3.函数中开启严格模式 2.函数 函数(function):相同代码块的集合 目的:就是为了实现某一特定的功能 函数的创建方式: 数据类型 函数表达式方式创建:只能在函数的后面调用(如果使用var,存在预解析以及变量提升) 3.函数和this关系 2.事件中this指向事件的触发者 3.定时器中this指向window 4.构造函数中的this指向实例对象 5.箭头函数中this没有指向(它的this就父级的this) 4.闭包 JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。 · 闭包(closure):有权访问另一个函数作用域中的变量的函数 闭包就是函数。 闭包的作用:扩展了变量的作用范围。(外部可以访问内部的变量) 结构: 外层函数的变量 + 内层函数 作用域
二、遇到问题
三、是否解决
|