首页 > 其他分享 >前端面试套题系列(第七篇)

前端面试套题系列(第七篇)

时间:2023-09-03 13:55:22浏览次数:38  
标签:缓存 const 面试 对象 Object 第七篇 obj return 套题

1、{}、new Object和Object.create的区别

主要区别

1、{} 和 new Object() 除了本身创建的对象,都继承了 Object 原型链上(Object.prototype)的属性或者方法,eg:toString();当创建的对象相同时,可以说 {} 等价于 new Object() 。
2、Object.create() 是将创建的对象继承到原型链上,而本身没有继承 Object.prototype 的属性和方法。

 

Object.cerate() 必须接收一个对象参数,创建的新对象的原型指向接收的参数对象,

new Object() 创建的新对象的原型指向的是 Object.prototype. (表述有点啰嗦,简洁点说就是前者继承指定对象, 后者继承内置对象Object)

可以通过Object.create(null) 创建一个干净的对象,也就是没有原型,

而 new Object() 创建的对象是 Object的实例,原型永远指向Object.prototype.

 

2、为什么vite在开发过程中会更快

ES modules:Vite 利用了浏览器本身对 ES modules 的原生支持,因此不需要打包构建就可以直接使用模块化的开发方式。这意味着在开发过程中只需要编译当前修改的文件,而不需要重新构建整个项目,从而提高了开发效率。

开发服务器:Vite 使用了基于浏览器原生 ES modules 支持的开发服务器,将每个单独的模块作为独立的文件服务,并且实现了按需编译。在开发时,每次修改文件保存后,只会重新编译这个文件,而不会重新编译整个项目,因此可以快速地进行开发测试。同时,Vite 使用了缓存机制,可以避免重复编译相同的文件。

esbuild 预构建:Vite 的 Dev 环境会进行预构建优化,Vite 是基于浏览器原生**支持 **ESM 的能力实现的,但要求用户的代码模块必须是ESM模块,因此必须将 commonJS 和 UMD 规范的文件提前处理,转化成 ESM 模块并缓存入 node_modules/.vite

 

3、点击内部div,执行onClick会发生什么

import React from 'react';

export function App() {
  const ref = React.useRef();

  React.useEffect(() => {
    ref.current.addEventListener('click', () => {
        console.log(123)
    })
  }, [])

  return (
    <div ref={ref} style={{ width: 200, height: 200, background: 'orange'}}>
      <div style={{ width: 100, height: 100, background: 'red'}} onClick={e => e.stopPropagation()}>123</div>
    </div>
   )
}

<div> 元素上添加了一个点击事件监听器,并且内层 <div> 元素的点击不会触发外层元素的点击事件。当点击内层 <div> 元素时,会输出 123 到控制台。

 

4、pnpm的依赖管理机制

hard link 机制: 计算机里面一个叫做 Hard link 的机制,hard link 使得用户可以通过不同的路径引用方式去找到某个文件。pnpm 会在全局的 store 目录里存储项目 node_modules 文件的 hard links 。

Store 目录:store 目录用于存储依赖的 hard links,一般 store 目录默认是设置在 ${os.homedir}/.pnpm-store 这个目录下。

 .npmrc 设置这个 store 目录位置,不过一般而言 store 目录对于用户来说感知程度是比较小的。

 

 5、react中 useMemo、useCallback区别

useMemouseMemo 用于在依赖项变化时,缓存一个计算结果。它接收两个参数:计算函数和依赖项数组。当依赖项数组中的任何一个值发生变化时,useMemo 会重新计算计算函数,并返回计算结果。

useCallbackuseCallback 用于缓存一个回调函数,以便在依赖项不变时,避免创建新的回调函数实例。它接收两个参数:回调函数和依赖项数组。当依赖项数组中的任何一个值发生变化时,useCallback 会返回一个新的回调函数。useCallback内部也是使用了useMemo来实现。

 

总结:

  • useMemo 用于缓存一个计算结果,在依赖项变化时重新计算。
  • useCallback 用于缓存一个回调函数,在依赖项变化时返回新的回调函数。

 

6、react实现一个关键字高亮组件

import React from 'react';

const KeywordHighlight = ({ text, keyword }) => {
  const highlightText = (text, keyword) => {
    const regex = new RegExp(`(${keyword})`, 'gi');
    return text.replace(regex, '<span class="highlight">$1</span>');
  };

  const highlightedText = {__html: highlightText(text, keyword)};

  return <div dangerouslySetInnerHTML={highlightedText} />;
};

export default KeywordHighlight;

 

7、js 实现一个深拷贝

function deepClone(obj) {
  // 判断是否为引用类型
  if (typeof obj !== 'object' || obj === null) {
    return obj; // 若是非引用类型,则直接返回
  }

  // 判断是否为数组
  if (Array.isArray(obj)) {
    const newArr = []; // 创建一个新数组
    for (let i = 0; i < obj.length; i++) {
      newArr.push(deepClone(obj[i])); // 递归拷贝数组元素
    }
    return newArr;
  }

  // 否则为普通对象
  const newObj = {}; // 创建一个新对象
  for (let key in obj) {
    newObj[key] = deepClone(obj[key]); // 递归拷贝对象属性
  }
  return newObj;
}

8、js 实现浏览器url参数获取,使用正则

function getUrlParams(url) {
  const regex = /[?&]([^=#]+)=([^&#]*)/g; // 匹配 URL 中的查询参数部分

  const params = {};
  let match;
  while (match = regex.exec(url)) {
    const key = decodeURIComponent(match[1]); // 解码参数名
    const value = decodeURIComponent(match[2]); // 解码参数值
    params[key] = value; // 存储参数到对象
  }

  return params;
}

9、下面这段代码输出什么

for (var i = 0; i < 3; i++) {
  setTimeout(function() { 
    console.log("a:"+i);
  }, 0);
  console.log("b:"+i);
}

输出:

b:0
b:1
b:2
3次 a:3 

 

10、实现一个函数,返回最长二叉树路径的长度

function getLongestPathLength(root) {
  let maxLength = 0; // 最长路径长度

  // 定义深度优先搜索函数
  function dfs(node) {
    if (node === null) {
      return 0; // 空节点的路径长度为0
    }

    // 递归计算左子树和右子树的最长路径长度
    const leftLength = dfs(node.left);
    const rightLength = dfs(node.right);

    // 计算以当前节点为根的最长路径长度
    const currentLength = leftLength + rightLength;

    // 更新最长路径长度
    maxLength = Math.max(maxLength, currentLength);

    // 返回当前节点为根的最长路径长度
    return Math.max(leftLength, rightLength) + 1;
  }

  dfs(root); // 调用深度优先搜索函数

  return maxLength;
}

 

11、讲一讲性能优化

一些常见的性能优化技巧:

  1. 减少重绘和重排:避免频繁改变页面布局、样式和结构,因为这会导致浏览器进行重绘和重排操作,影响性能。尽量使用 CSS 类名的方式进行样式修改,使用 requestAnimationFrame 来优化动画效果。

  2. 避免过多的 DOM 操作:DOM 操作比较昂贵,可以将多个 DOM 操作进行批量处理,或者使用文档片段(DocumentFragment)进行离线操作后再一次性插入到文档中。

  3. 使用事件委托:将事件监听器绑定到父元素上,通过事件冒泡机制来处理子元素的事件,减少监听器的数量,提高性能。

  4. 避免频繁的重复计算:在需要多次计算的地方,可以将结果缓存起来,避免重复计算。

  5. 使用节流和防抖:对于频繁触发的事件(如窗口大小改变、滚动等),可以使用节流(throttling)和防抖(debouncing)来限制事件的触发频率,减少函数的调用次数。

  6. 缓存数据:对于频繁使用的数据,可以将其缓存起来,避免重复获取或计算。

  7. 合并和压缩文件:将多个 JavaScript 和 CSS 文件合并为一个文件,并进行压缩,减少网络请求和文件大小,提高加载速度。

  8. 使用 Web Workers:对于耗时的操作,可以使用 Web Workers 进行多线程处理,避免阻塞主线程。

  9. 避免不必要的网络请求:减少不必要的 AJAX 请求、图片加载等网络请求,尽量使用缓存。

  10. 使用性能分析工具:使用浏览器开发者工具的性能分析功能来识别瓶颈,并进行针对性的优化。

 

标签:缓存,const,面试,对象,Object,第七篇,obj,return,套题
From: https://www.cnblogs.com/cczlovexw/p/17674916.html

相关文章

  • 一道经典面试题:@Configuration 和 @Component 有何区别?
    关于@Configuration注解有一个特别经典的面试题:@Configuration和@Component有什么区别?无论小伙伴们之前是否背过相关的面试题,今天这篇文章学完之后相信大家对这个问题都会有更深一层的理解,废话不多少,咱们开始分析。1.情景展现@Configuration和@Component到底有何区别呢?我......
  • 嵌入式面试笔试刷题(day14)
    (文章目录)前言本篇文章继续我们的刷题之路。一、进程控制块这里只讲解进程的PCB控制块,线程的TCP控制块作用和进程PCB控制块作用类似。1.PCB控制块的作用进程控制块(ProcessControlBlock,PCB)是操作系统中用于管理和跟踪进程信息的数据结构。每个进程在操作系统中都有一个对......
  • HashMap线程安全面试题(含答案)
    HashMap线程安全面试题(含答案)Java中平时用的最多的Map集合就是HashMap了,它是线程不安全的。看下面两个场景:1、当用在方法内的局部变量时,局部变量属于当前线程级别的变量,其他线程访问不了,所以这时也不存在线程安全不安全的问题了。2、当用在单例对象成员变量的时候呢?这时候多个线......
  • Java Map常见面试题
    你好,面试官|你拿JavaMap考验老干部?面试官:请说下对理解HashMap及LinkedHashMap的理解(八股文)(qq.com)你用过哪些Map?HashMap、LinkedHashMap、TreeMap、ConCurrentHashMap一般涉及到键值对的存取,我们第一时间想到的就是HashMap如果需要根据Key顺序实现存储键值对,TreeMap较......
  • 来玩,前端性能优化(+面试必问:宏任务和微任务)
    前端性能优化相关的“技能点”笔者之前也写过几篇,但是大多都是小打小闹。我重新整理了曾经使用过的性能优化手段。本文介绍三种方案:页面资源预加载、服务请求优化和非首屏视图延迟加载。页面资源预加载页面是不可能真正预加载的,但是有一个地方:入口代码中依赖的js模块。一般来说,......
  • 软件测试面试题
    软件测试的流程?考察目的:软件测试基础参考答案:需求评审(需求是否合理、是否可测)->测试计划(人、时间、业务点、资源)->测试设计(测试用例)->冒烟测试(准入测试,基本业务测试不通过直接打回)->测试执行(环境、工具搭建、用例执行)->bug提交->新版本发布(bug有没有验证、新功能......
  • Java集合面试之Queue篇
    Java集合面试之Queue篇(qq.com)1、队列是什么?队列是常用数据结构之一。是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,故为先进先出(FIFO,firstinfirstout)线性表。和栈一样,队列是一种操作受限制的线性表。2、队列的分类?Qu......
  • Java List常见面试题
    Java集合面试之List篇你好,面试官|我用JavaList狂怼面试官~(qq.com)本文涉及ArrayList与LinkedList区别、ArrayList扩容机制、CopyOnWriteArrayList特点、场景、思想ArrayList:基于数组实现的非线程安全的集合。实现RandomAccess接口,支持随机访问,查询元素快,插入,......
  • 20230829-面试题html+css5道题记录
    css预处理工具参考答案:CSS预处理器是一个能让你通过预处理器自己独有的语法来生成CSS的程序。css预处理器种类繁多,三种主流css预处理器是Less、Sass(Scss)及Stylus;它们各自的背景如下:Sass:2007年诞生,最早也是最成熟的CSS预处理器,拥有ruby社区的支持和compass这一最强大的css框......
  • 20230825-面试题html+css5篇简单记录
    html标签的类型(head,body,!Doctype)他们的作用是什么!DOCTYPE标签:它是指示web浏览器关于页面使用哪个HTML版本进行编写的指令.head:是所有头部元素的容器,绝大多数头部标签的内容不会显示给读者该标签下所包含的部分可加入的标签有base,link,meta,script,style和title......