js知识库

embedded/2024/10/21 3:48:18/

script标签的async和defer作用及区别

1)都会起到延迟执行js的作用

2)defer:先进行html解析,解析过程中会下载js文件,但不会执行;当html完全解析完,才会执行js部分。多个用defer修饰的js是顺序执行的。

3)async :async修改的js文件,下载和执行是和html解析同步的;多个用async 修饰的js不是顺序执行的,哪个js先加载完哪个先执行。

js数据类型有哪些

基本数据类型:String、Number、Boolean、undefined、null、symbol

引用数据类型:Object

javascript">console.log(true + 1) //2
//字符串和任何类型 相加,其他类型将被隐式转换为字符串
console.log('name'+true) //'nametrue'
console.log(undefined + 1)// NaN (NaN为number类型)
console.log(typeof null)//Object
console.log(typeof NaN)//Number
console.log(typeof undefined) //undefined

null和undefined含义及区别

1) javascript作者在设计js语言最先设计了null,待表“无”的值。

2)null被设计成可以隐式转换为0。

3)具体区别:null是一个表示“无”的对象(空对象指针),转为数值时为0;undefined是表示一个“无”的原始值,转换数值时为NAN。

==和===有什么区别

1)==:比较的是值,不对比数据类型,比较时不同类型的值会被隐式转换为同一类型(转换为基础数据类型)自动转换,不显示在代码中。

2)===:不但比较值,还比较数据的类型

注意:隐式转换用的方法是valueOf()

拓展:

javascript">//修改javaScript上的valueOf方法,修改javaScript内置其他方法也类似
Object.prototype.valueOf = function(){console.log('123')
}

js的微任务和宏任务

js是单线程的语言,同一时间只能做一件事;单线程语言设计的原因:javaScript主要用途是实现交互及操作dom,如果同时存在2个线程,一个添加节点、一个删除这个节点,这时浏览器不知道应该以哪个线程为准。设计为单线程语言,避免了很多复杂的同步问题。

js代码执行顺序

js先执行同步任务 ,执行完之后才会进入到事件循环中。进入事件循环:请求ajax、定时器、事件

事件循环包含【微任务、宏任务】 

微任务:promise.then

宏任务:setTimeout

流程:同步 ==》事件循环【微任务和宏任务】==》微任务==》宏任务=》微任务

执行宏任务前提,把微任务清完

js的作用域

全局变量:挂载在window下面

局部变量:挂在到函数内部

 作用域链:函数内部可以访问外面的变量,外部不可以访问函数内部的变量。如果函数内部有,先取函数内部的。注意变量提升。

优先级:声明变量 > 声明函数

javascript">function fun(){var a = 10function a(){}    //可以进行变量提升console.log(a)//a为10
}
fun()
function fun1(){var a = 10var a = funciton(){}    //不能进行变量提升console.log(a)//a为函数
}
fun1()

call、applay、bind的共同点及区别

共同点:都能改变函数的this指向

区别

1.改变this指向后函数的执行顺序不同

call:改变完this的指向后,并立即执行函数

apply:改变完this的指向后,并立即执行函数

bind:改变完this的指向,并返回一个函数,得手动调用一下函数才能执行

2.给函数传参形式不同

call和bind都是一个一个参数传递,apply是数组形式传递


http://www.ppmy.cn/embedded/37230.html

相关文章

《Video Mamba Suite》论文笔记(1)Mamba在时序建模中的作用

原文链接 https://arxiv.org/abs/2403.09626https://arxiv.org/abs/2403.09626 原文代码 https://github.com/OpenGVLab/video-mamba-suitehttps://github.com/OpenGVLab/video-mamba-suite 原文笔记 What 《Video Mamba Suite: State Space Model as a Versatile Altern…

【吃透Java手写】Spring(下)-AOP-事务及传播原理

【吃透Java手写】Spring(下)AOP-事务及传播原理 6 AOP模拟实现6.1 AOP工作流程6.2 定义dao接口与实现类6.3 初始化后逻辑6.4 原生Spring的方法6.4.1 实现类6.4.2 定义通知类,定义切入点表达式、配置切面6.4.3 在配置类中进行Spring注解包扫描…

Spring IOC 和 AOP

相关注解可参考:http://t.csdnimg.cn/yfUKt 1.什么是IOC和AOP Spring框架中的IOC(Inverse of Control,控制反转)和AOP(Aspect-Oriented Programming,面向切面编程)是其两大核心特性&#xff0c…

(CDA数据分析师笔记)第六章 业务分析方法五

产品库存类指标 库存手进货与销售双方向的影响。 期初库存:单位时间的起点处库存量。 期末库存:单位时间的终点处库存量。 常见指标: 库存数量与库存金额:可以是某时点或者某时段平均值。 有两个计算方法: 计算方…

leetcode 547.省份数量

思路:dfs 或者这道题用bfs也是可以的。 这道题有点迷惑性,这里的数组给的是无向图的数组,而并不是地图,这里需要着重注意一下。 而后,这里的状态数组st没必要是二维的,我们并不会去遍历所给的数组&#…

如何根据索引删除数组中的元素,并保证删除的正确性

使用 splice() 方法来删除这些索引处的数据 var array [1, 2, 3, 4, 5]; var indexesToDelete [1, 3]; // 需要删除的索引// 将需要删除的索引按照从大到小的顺序排序,以避免删除元素后索引发生变化 indexesToDelete.sort((a, b) > b - a);// 遍历需要删除的索…

计算机行业AI前沿报告:混合专家模型技术(MoE)

今天分享的是****AI系列深度研究报告:《计算机行业AI前沿报告:混合专家模型技术(MoE)》。(报告出品方:中信建投证券) 精选内容来源公众:见鹿报告 报告共计: 24页 [报告内容摘要如下] **•核心观点&…

JavaScript百炼成仙自学笔记——2

一、循环遍历&#xff1a; 方式一 for(var i0;i<10;i){console.log(i); }方式二 var i 0; while(i < 100){console.log(i);i; }细看代码就是 先定义变量i&#xff0c;再执行{}中的代码&#xff0c;最后改循环变量的值 二、遍历 什么事遍历&#xff1f; 什么时候会用…