菁英数字科技(猩码)-猩码学苑-专注软件开发人才菁英教育
标题: 前端-张静博-2023-5-31 [打印本页]
作者: JBZ 时间: 2023-6-14 18:48
标题: 前端-张静博-2023-5-31
一、学习内容
函数的应用场景和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):有权访问另一个函数作用域中的变量的函数
闭包就是函数。 闭包的作用:扩展了变量的作用范围。(外部可以访问内部的变量) 结构: 外层函数的变量 + 内层函数 作用域
二、遇到问题
三、是否解决
欢迎光临 菁英数字科技(猩码)-猩码学苑-专注软件开发人才菁英教育 (http://www.xingmaxueyuan.com/) |
Powered by Discuz! X3.4 |