公司面试题总结(二)

news2025/1/18 2:01:06

7. 说说 JavaScript 中的数据类型?存储上的差别?

基本类型:

        o Number
        o String
        o Boolean
        o Undefined
        o null
        o symbol

引用类型

        o Object
        o Array
        o Function

声明变量时不同的内存地址分配:

        o 简单类型的值存放在 中,在栈中存放的是对应的值
        o 引用类型对应的值存储在 中,在栈中存放的是指向堆内存的地址

不同的类型数据导致赋值变量时的不同:

        o 简单类型赋值 ,是生成相同的值,两个对象对应不同的地址
        o 复杂类型赋值
                ▪ 是将保存对象的内存地址赋值给另一个变量。
                ▪ 也就是两个变量指向堆内存中同一个对象

8. typeof 与 instanceof 区别 ,常见的数据类型有哪些,区 别是什么?

typeof 会返回一个变量的基本类型,instanceof 返回的是一个布尔值
instanceof 可以准确地判断复杂引用数据类型,但是不能正确判断基础数据类型
而 typeof 也存在弊端,它虽然可以判断基础数据类型(null 除外),但是引用数据类
型中,除了 function 类型以外,其他的也无法判断
JavaScript 中常用的数据类型判断方法有以下 5 种:
typeof 操作符:可以返回一个字符串,用于表明所操作数的类型。
instanceof 操作符:可以判断一个对象是否属于某个类(或其子类)。
Object.prototype.toString() 方法:可以返回一个表示调用它的对象所属类的字符串。
constructor 属性:可以返回对创建该对象的数组函数的引用。
Array.isArray() 方法:可以判断一个值是否为数组。
        这些方法的区别如下:
typeof 只能区分基本数据类型,不能区分具体的对象类型。
instanceof 只能用于判断对象类型,无法判断基本数据类型
Object.prototype.toString() 方法可以返回对象类型的具体字符串
constructor 属性可以返回对象所属类的构造函数
Array.isArray() 可以判断一个值是否为数组

9. 说说你对闭包的理解?闭包使用场景

闭包指在一个函数内部定义的函数可以访问外部函数作用域中的变量,即使外部函数已经执
行完毕,这种能力称为“闭包”。

优点:

封装变量:

创建私有变量和函数,这样可以避免全局命名冲突,提高代码的可维护性。

延长变量的生命周期:

外部函数执行完毕后,其内部变量不会被销毁,而是被内部函数持有
可以延长变量的生命周期,使得外部函数的变量在内部函数中仍然可用。

实现柯里化:

将接受多个参数的函数转化为接受单一参数的函数
并返回接受剩余参数的函数。

缺点:

内存泄漏:

持有对外部函数作用域的引用,如果这个引用被持续保留
那么外部函数中的变量就无法被释放,导致内存占用过高。

性能问题:

闭包会增加内存消耗和运行时的开销,因为需要维护额外的作用域链。
特别是在循环中使用闭包,可能会导致性能问题。

复杂性:

过度使用闭包可能会导致代码变得难以理解和维护,
闭包使得函数之间的关系变得更加复杂,增加了代码的复杂性和理解成本。

10.bind、call、apply 区别?如何实现一个 bind?

三者第一个参数都是 this 要指向的对象,如果没有这个参数或参数为 undefined 或
        null,则默认指向全局 window
三者都可以传参,但是 apply 是数组,而 call 是参数列表,且 apply 和 call 是一次性
        传入参数,而 bind 可以分为多次传入
bind 是返回绑定 this 之后的函数,apply、call 则是立即执行
实现 bind 的步骤,我们可以分解成为三部分:
        o 修改 this 指向
        o 动态传递参数
                // 方式一:只在 bind 中传递函数参数
                fn.bind(obj,1,2)()
                // 方式二:在 bind 中传递函数参数,也在返回函数中传递参数
                fn.bind(obj,1)(2)
        o 兼容 new 关键字
        Function.prototype.myBind = function (context) {
                // 判断调用对象是否为函数
                if (typeof this !== "function") {
                throw new TypeError("Error");
                }
                // 获取参数
                const args = [...arguments].slice(1),
                fn = this;
                return function Fn() {
                // 根据调用方式,传入不同绑定值
                return fn.apply(this instanceof Fn ? new fn(...arguments) : context,
               args.concat(...arguments));
        }
}

11.说说你对事件循环的理解,宏任务和微任务的理解?

JavaScript 是一门单线程的语言,意味着同一时间内只能做一件事,但是这并不意味着单线
程就是阻塞,而实现单线程非阻塞的方法就是 事件循环
在 JavaScript 中,所有的任务都可以分为:
同步任务:立即执行的任务,同步任务一般会直接进入到主线程中执行
异步任务:异步执行的任务,比如 ajax 网络请求,setTimeout 定时函数等
同步任务进入主线程,即主执行栈,
异步任务进入任务队列
主线程内的任务执行完毕为空,会去任务队列读取对应的任务,推入主线程执行。 上述过程的不断重复就事件循环

微任务

一个需要异步执行的函数,执行时机是主函数执行结束之后、当前宏任务结束之前
Promise.then
MutaionObserver
Object.observe(已废弃;Proxy 对象替代)
process.nextTick(Node.js)

宏任务

宏任务的时间粒度比较大,执行的时间间隔是不能精确控制的,对一些高实时性的
需求就不太符合
script (可以理解为外层同步代码)
setTimeout/setInterval
UI rendering/UI 事件
postMessage、MessageChannel
setImmediate、I/O(Node.js)
按照这个流程,它的执行机制是:
执行一个宏任务,如果遇到微任务就将它放到微任务的事件队列中
当前宏任务执行完成后,会查看微任务的事件队列,然后将里面的所有微任务依次执行

12.DOM 常见的操作有哪些?

DOM(文档对象模型) 是用于表示 HTML 和 XML 文档的树状结构,并且允许程序和脚
本动态地访问和更新文档内容、结构和样式。在 JavaScript 中,常见的 DOM 操作包括
但不限于以下几种:

文档对象模型 (DOM) :

HTML 和 XML 文档的编程接口
提供了对文档的结构化的表述
定义了一种方式可以使从程序中对该结构进行访问,从而改变文档的结构,样式和内容
任何 HTML 或 XML 文档都可以用 DOM 表示为一个由节点构成的层级结构
<p title="title">content</p >
p 就是元素节点,
content 就是文本节点,
title 就是属性节点

创建节点

createElement
创建新元素,接受一个参数,即要创建元素的标签名
const divEl = document.createElement("div");
createTextNode
创建一个文本节点
const textEl = document.createTextNode("content");
createDocumentFragment
用来创建一个文档碎片,它表示一种轻量级的文档,主要是用来存储临时节
点,然后把文档碎片的内容一次性添加到 DOM 中 const fragment = document.createDocumentFragment();
当 请 求 把 一 个 DocumentFragment 节点插入文档树时,插入的不
是 DocumentFragment 自身,而是它的所有子孙节点
createAttribute
创建属性节点,可以是自定义属性
const dataAttribute = document.createAttribute('custom');

获取节点

document. getElementById ('id 属性值');返回拥有指定 id 的对象的引用
document. getElementsByClassName ('class 属性值');返回拥有指定 class 的对象集
document. getElementsByTagName ('标签名');返回拥有指定标签名的对象集合
document. getElementsByName ('name 属性值'); 返回拥有指定名称的对象结合
document/element. querySelector ('CSS 选择器'); 仅返回第一个匹配的元素
document/element. querySelectorAll ('CSS 选择器'); 返回所有匹配的元素
document. documentElement ; 获取页面中的 HTML 标签
document. body ; 获取页面中的 BODY 标签
document. all ['']; 获取页面中的所有元素节点的对象集合型
除此之外,每个DOM 元素还有parentNode、childNodes、firstChild、lastChild、nextSibling、
previousSibling 属性

更新节点

innerHTML
不但可以修改一个 DOM 节点的文本内容
还可以直接通过 HTML 片段修改 DOM 节点内部的子树
innerText、textContent
自动对字符串进行 HTML 编码,保证无法设置任何 HTML 标签
innerText 不返回隐藏元素的文本,
textContent 返回所有文本
style
DOM 节点的 style 属性对应所有的 CSS,可以直接获取或设置。
遇到-需要转化为驼峰命名

添加节点

innerHTML
如果这个 DOM 节点是空的,直接使用 innerHTML = '<span>child</span>'
修改 DOM 节点的内容,相当于添加了新的 DOM 节点
appendChild
把一个子节点添加到父节点的最后一个子节点
insertBefore
把子节点插入到指定的位置,使用方法如下:
parentElement.insertBefore(newElement, referenceElement)
setAttribute(属性名,属性值)
在指定元素中添加一个属性节点,如果元素中已有该属性改变属性值

删除节点

调用父节点的 removeChild 把自己删掉
删除后的节点虽然不在文档树中了,但其实它还在内存中,可以随时再次被添加到 别的位置

替换节点:

parentNode. replaceChild (newNode, oldNode): 替换一个子节点为新的节点。

查找相邻节点:

element. nextElementSibling : 获取当前元素的下一个兄弟元素。
element. previousElementSibling : 获取当前元素的上一个兄弟元素。

获取元素尺寸和位置:

element. offsetWidth 和 element. offsetHeight : 获取元素的布局宽度和高度,包
含边框和内边距。
element. clientWidth 和 element. clientHeight : 获取元素内容区的宽度和高度,
不包括滚动条、边框和外边距。
element. getBoundingClientRect (): 获取元素相对于视口的位置和尺寸信息。

事件处理:

element. addEventListener (eventType, callback): 给元素添加指定事件类型的监听
器。
element. removeEventListener (eventType, callback): 移除元素指定事件类型的监
听器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1802187.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

德克萨斯大学奥斯汀分校自然语言处理硕士课程汉化版(第六周) - 预训练模型

预训练模型 1. 预训练模型介绍 1.1. ELMo1.2. GPT1.3. BERT 2. Seq2Seq 2.1. T52.2. BART 3. Tokenization 1. 预训练模型介绍 在预训练语言模型出现之前&#xff0c;统计语言模型&#xff08;如N-gram模型&#xff09;是主流方法。这些模型利用统计方法来预测文本中的下一个…

浙江大学蒋明凯研究员《Nature》正刊最新成果!揭示生态系统磷循环响应大气二氧化碳浓度升高关键机制

随着大气二氧化碳浓度的升高&#xff0c;陆地生态系统固存额外碳汇的能力取决于土壤养分的可利用性。前期的研究证据表明&#xff0c;在土壤低磷环境下&#xff0c;大气二氧化碳浓度的升高可以提升成熟森林的光合速率&#xff0c;但是没有产生额外生物量固碳。热带和亚热带森林…

自定义idea插件之hello idea plugin

写在前面 最近一直想研究下自定义idea插件的内容&#xff0c;这样如果是想要什么插件&#xff0c;但又一时找不到合适的&#xff0c;就可以自己来搞啦&#xff01;这不终于有时间来研究下&#xff0c;但过程可谓是一波三折&#xff0c;再一次切身体验了下万事开头难。那么&…

自然语言处理:第三十二章HippoRAG:性能提高20% - 受海马体启发的RAG

文章链接: HippoRAG: Neurobiologically Inspired Long-Term Memory for Large Language Models 项目地址: OSU-NLP-Group/HippoRAG: HippoRAG is a novel RAG framework inspired by human long-term memory that enables LLMs to continuously integrate knowledge across e…

macbook本地部署 pyhive环境连接 hive用例

前言 公司的测试和生产环境中尚未提供基于Hive的客户端。若希望尝试操作Hive表&#xff0c;目前一个可行的方案是使用Python语言&#xff0c;通过借助pyhive库&#xff0c;您可以对Hive表进行各种操作。以下是一些示例记录供您参考。 一、pyhive是什么&#xff1f; PyHive是一…

电脑提示缺失iUtils.dll文件怎么办,分享几种靠谱的解决方法

在现代科技发展迅猛的时代&#xff0c;电脑已经成为我们生活和工作中不可或缺的工具。然而&#xff0c;随着使用时间的增长&#xff0c;电脑也会出现一些问题&#xff0c;其中之一就是开机时弹出窗口提示找不到iUtils.dll文件。这个问题可能会给用户带来困扰和不便&#xff0c;…

[AIGC] Springboot 自动配置的作用及理由

在详细解释SpringBoot的自动配置之前&#xff0c;先介绍以下背景知识。在创建现代复杂的应用程序时&#xff0c;一个困难的部分是正确地设置您的开发环境。这个问题尤其在Java世界中尤为突出&#xff0c;因为您必须管理和配置许多独立的标准和技术。 当我们谈论Spring Boot的自…

react 基础样式的控制(行内和className)

import ./index.cssconst style{color:red,font-size:150px }function App() {return (<div className"App"><h1>行内样式控制</h1><h1 style{{color:red,font-size:150px}} >asd </h1><span style{style} >asd </span>&l…

二叉排序树--c++

【相关知识】 二叉排序树&#xff08;也称二叉查找树&#xff09;&#xff1a;或者是一棵空的二叉树&#xff0c;或者是具有下列性质的二叉树&#xff1a; ⑴ 若它的左子树不空&#xff0c;则左子树上所有结点的值均小于根结点的值&#xff1b; ⑵ 若它的右子树不空&#xff0c…

基本算法-枚举、模拟、递推(上)

目录 递归实现指数型枚举 题目描述 运行代码 代码思路 递归实现组合型枚举 题目描述 运行代码 代码思路 递归实现排列型枚举 题目描述 运行代码 代码思路 递归实现指数型枚举 题目描述 登录—专业IT笔试面试备考平台_牛客网 运行代码 #include<iostream> …

Java装饰器模式,装饰器模式通常通过创建一个接口和一个或多个实现了该接口的类来开始,然后创建装饰器类,这些类也实现了相同的接口

1、定义一个接口Component public interface Component { void operation(); }2、创建一个实现了Component接口的简单类SimpleComponent public class SimpleComponent implements Component { Override public void operation() { System.out.println("SimpleCom…

【JS重点知识05】正则表达式

本文章目标&#xff1a;学习正则表达式概念及语法&#xff0c;编写简单的正则表达式实现字符查找或检测&#xff1b; 一&#xff1a;正则表达式简介 1 什么是正则表达式 是用于匹配字符串中字符组合的模式。在JS中&#xff0c;正则表达式也是对象 2 正则表达式作用 表单验…

【C#】WinForm关闭新(二级)界面使主程序关闭

参考视频&#xff1a;https://www.bilibili.com/video/BV1JY4y1G7jo?p14&vd_source1c57ab1b2e551da5b65c0dfb0f05a493 1.背景介绍 主程序界面&#xff0c;点击弹出二级界面&#xff08;同时隐藏主界面&#xff09;&#xff0c;不做任何设置&#xff0c;这时关闭二级界面…

FM1202,FM020和利时备品

FM1202,FM020和利时备品,统硬件设备、数据库、控制算法、图形、报表&#xff09;和相关系统参数的设置。对整个系统进行监视和控制。操作员站主要完成以下FM1202,FM020和利时备品,各种监视信息的显示、查询和打印&#xff0c;主要有工艺流程图显示、趋势显示、参数列表显示、报…

将二叉排序树转换成双向链表--c++【做题记录】

【问题描述】 编写程序在不增加结点的情况下&#xff0c;将二叉排序树转换成有序双向链表&#xff08;如下图&#xff09;。 链表创建结束后&#xff0c;按照从前往后的顺序输出链表中结点的内容。 【输入输出】 【输入形式】 第一行输入数字n&#xff0c;第二行输入n个整数…

【CS.SE】浅谈: 程序员的职业素养与成长之路

文章目录 1 引言2 持续学习与自我提升2.1 永无止境的学习之路2.2 真实案例&#xff1a;自学Python 3 团队合作与沟通能力3.1 高效沟通是团队成功的基石 4 责任心与职业道德4.1 责任心&#xff1a;代码背后的承诺4.2 真实案例&#xff1a;修复紧急Bug 5 适应变化与快速反应5.1 适…

Linux安装MySQL教程【带图文命令巨详细】

巨详细Linux安装MySQL 1、查看是否有自带数据库或残留数据库信息1.1检查残留mysql1.2检查并删除残留mysql依赖1.3检查是否自带mariadb库 2、下载所需MySQL版本&#xff0c;上传至系统指定位置2.1创建目录2.2下载MySQL压缩包 3、安装MySQL3.1创建目录3.2解压mysql压缩包3.3安装解…

用Python代码锁定Excel单元格以及行和列

Excel能够帮助用户高效地组织数据&#xff0c;还支持复杂的公式计算和数据分析。而随着团队协作的日益频繁&#xff0c;保护数据的准确性和完整性变得尤为重要。在Excel表格中&#xff0c;我们可以通过锁定特定的单元格或区域&#xff0c;防止对单元格内容进行随意修改&#xf…

2024年全国大学生数据统计与分析竞赛B题论文和代码:电信银行卡诈骗检测数据分析和机器学习模型构建

2024年全国大学生数据统计与分析竞赛B题论文和代码已完成&#xff0c;代码为B题全部问题的代码&#xff0c;论文包括摘要、问题重述、问题分析、模型假设、符号说明、模型的建立和求解&#xff08;问题1模型的建立和求解、问题2模型的建立和求解、问题3模型的建立和求解&#x…

人工智能--Foxmail邮箱使用方法

目录 &#x1f349;Foxmail全面指南 &#x1f349;下载与安装 &#x1f348;下载软件 &#x1f348;安装软件 &#x1f349;配置邮箱 &#x1f348;启动 Foxmail &#x1f348;添加邮箱账户 &#x1f348;手动配置邮箱 &#x1f34d;接收邮件服务器 (IMAP/POP3) &…