当前位置: 首页 > news >正文

5.9号模拟前端面试10问

5.9号模拟前端面试10问

1.html语义化的理解

HTML语义化是指使用具有明确含义的HTML标签来描述内容,而不仅仅是使用<div><span>等通用容器标签。语义化的HTML代码更易于阅读和维护,同时也有助于搜索引擎优化(SEO)。

例如,使用<header><nav><main><article><section><aside><footer>等语义化标签,可以清晰地表达页面的结构。这些标签不仅有助于开发者理解代码,还有助于浏览器更好地解析和渲染页面。同时也有助于提高网站的可访问性和搜索引擎排名。

2. < b>和< strong>的区别

标签在HTML中都用于加粗文本,但它们在语义上有所不同。

标签是用于表示简单的样式变化,它不会给文本增加任何额外的强调或重要性。它只是简单地将文本变为粗体,而不会改变文本的语义。

标签则具有更强的语义含义,它表示文本具有重要的意义或强调。搜索引擎会识别标签并将其视为关键词,有助于提高SEO效果。此外,对于视觉障碍的用户,屏幕阅读器通常会以不同的方式读出标签的内容,使其更加突出。

私信【学习】即可获取前端资料 都整理好啦!!!

在浏览器默认样式中,标签通常没有特殊的视觉差异,而标签可能会显示为更粗的字体或其他强调样式,具体取决于浏览器的默认样式表。

总的来说,标签适用于简单的样式变化,而标签适用于强调或重要的文本。在SEO和可访问性方面,使用标签可以提供更好的效果。

3.对闭包的理解

闭包就是一个函数能够访问它外面的那个作用域里的变量,即使外面的代码已经运行完了。在JavaScript里,我们通过把一个函数放在另一个函数里面,以及利用词法作用域的规则来实现闭包。

闭包的好处在于它能够让函数保留一些信息,这样即使函数被多次调用,它也能记得之前的一些东西。这对于创建只属于函数自己的秘密变量和实现模块化编程等地方特别有用。

下面是一个闭包的代码示例:

function outer() {let count = 0;function inner() {count++;console.log(count);}return inner;
}const counter = outer();
counter(); // 输出 1
counter(); // 输出 2

在这个例子中,inner函数可以访问outer函数中的count变量,即使outer函数已经执行完毕。每次调用counter时,count的值都会递增。这就是闭包的作用。

4.⼯程中闭包使⽤场景

闭包(closures)是JavaScript中的一个重要概念,它允许一个函数访问并操作其外部作用域中的变量,即使在外部函数已经执行完毕之后。

闭包对内存管理的影响主要体现在它可以让局部变量在函数执行完毕后仍然保留在内存中,因为这些局部变量被外部函数的引用所持有。这有助于实现私有变量和持久化状态,但过度使用闭包可能会导致内存占用过高。

闭包在实际编程中的应用场景包括:

  1. 创建私有变量:通过闭包,我们可以创建只能在特定作用域内访问的变量,从而实现封装和数据隐藏。
  2. 实现模块化:闭包可以帮助我们将代码模块化,每个模块都有自己的独立作用域,不会污染全局作用域。
  3. 实现高阶函数:闭包使得我们可以将函数作为参数传递给其他函数,或者将函数作为返回值返回。

下面是一个利用闭包实现私有变量的代码示例:

function counter() {let count = 0;function increment() {count++;return count;}return increment;
}const myCounter = counter();
console.log(myCounter()); // 输出 1
console.log(myCounter()); // 输出 2

在这个例子中,counter函数返回了一个内部函数increment,这个内部函数可以访问并修改count变量。当我们调用myCounter时,它会保留上一次调用时count的值,从而实现了计数器的功能。这种实现方式的优势在于,count变量是私有的,不能直接访问和修改,保证了数据的安全性。同时,每次调用myCounter时,都会返回一个新的闭包,实现了多个独立的计数器。

5.介绍this和原型

在JavaScript中,"this"关键字是一个特殊的变量,它在函数内部被自动定义。它的值取决于函数的调用方式。例如,如果一个函数以方法的形式被调用,那么"this"通常指向调用它的对象。如果一个函数以函数的形式被调用(即非方法形式),那么"this"通常指向全局对象(在浏览器中是window)。

原型(prototype)是JavaScript中的一个核心概念,它是实现继承的主要机制。每个JavaScript对象都有一个原型对象,当我们试图访问一个对象的属性时,如果该对象本身没有这个属性,那么JavaScript会去它的原型对象上找。

"this"和原型在JavaScript中非常重要,因为它们是实现面向对象编程的关键。例如,我们可以使用原型来实现共享属性和方法,从而减少内存消耗。同时,"this"关键字可以帮助我们更好地理解和控制函数的行为。

以下是一个代码示例,展示了"this"和原型在实际开发中的应用:

function Person(name, age) {this.name = name;this.age = age;
}Person.prototype.sayHello = function() {console.log("Hello, my name is " + this.name);
}var person1 = new Person("Alice", 20);
person1.sayHello(); // 输出 "Hello, my name is Alice"

在这个例子中,我们定义了一个Person构造函数,并使用"this"关键字来设置其属性。然后,我们在Person的原型上定义了一个sayHello方法,这样所有的Person实例都可以共享这个方法,而不是每个实例都有自己的sayHello方法副本。

私信【学习】即可获取前端资料 都整理好啦!!!

6.使⽤原型最⼤的好处

使用原型的最大好处是实现对象之间的共享和重用。通过将共享的属性和方法定义在原型上,而不是每个实例中,可以减少内存消耗并提高性能。此外,当需要修改或扩展方法时,只需修改原型上的方法即可,所有实例都会自动继承这些更改。

以下是一个代码示例,展示了如何使用原型实现对象之间的共享:

function Person(name) {this.name = name;
}Person.prototype.sayHello = function() {console.log("Hello, my name is " + this.name);
}var person1 = new Person("Alice");
var person2 = new Person("Bob");person1.sayHello(); // 输出 "Hello, my name is Alice"
person2.sayHello(); // 输出 "Hello, my name is Bob"

在这个例子中,我们定义了一个Person构造函数,并在其原型上定义了一个sayHello方法。这样,所有的Person实例都可以共享这个方法,而不是每个实例都有自己的sayHello方法副本。

7. react设计思路

在React中进行设计时,我首先会考虑组件化的思想。我会将整个应用划分为多个独立的组件,每个组件负责一个特定的功能或界面部分。这样可以提高代码的可维护性和复用性。

接下来,我会使用状态管理来管理组件之间的数据传递和共享。React提供了Context API和Redux等工具来实现状态管理。通过使用这些工具,我可以确保组件之间能够正确地共享和更新数据。

此外,我会注重组件的可测试性。React提供了一些测试工具,如Jest和Enzyme,可以帮助我编写单元测试和集成测试,确保组件的正确性和稳定性。

最后,我会关注性能优化。React提供了一些性能优化的技巧,如使用虚拟DOM、合理使用 shouldComponentUpdate 生命周期方法等,以提高应用的性能和用户体验。

以下是一个简单的React组件示例:

import React, { useState } from 'react';function Counter() {const [count, setCount] = useState(0);const increment = () => {setCount(count + 1);};return (<div><p>Count: {count}</p><button onClick={increment}>Increment</button></div>);
}export default Counter;

在这个示例中,我创建了一个简单的计数器组件。它使用了useState Hook来管理计数器的值,并在点击按钮时增加计数。这个组件可以独立使用,也可以与其他组件进行组合和复用。

8.为什么虚拟DOM⽐真实DOM性能好

私信【学习】即可获取前端资料 都整理好啦!!!

虚拟DOM相较于真实DOM在性能方面的优势主要体现在以下几个方面:

  1. 减少重排和重绘:真实DOM的操作会导致页面的重排和重绘,而虚拟DOM通过对比新旧虚拟DOM的差异,只更新需要改变的部分,从而减少了重排和重绘的次数。

  2. 批量更新:虚拟DOM可以将多次操作合并为一次批量更新,减少了频繁的操作导致的性能损耗。

  3. 跨平台渲染:虚拟DOM可以在不同的平台上进行渲染,如浏览器、服务器等,提高了代码的可移植性和灵活性。

以下是一个使用虚拟DOM的React代码示例:

import React, { useState } from 'react';function App() {const [count, setCount] = useState(0);const increment = () => {setCount(count + 1);};return (<div><p>Count: {count}</p><button onClick={increment}>Increment</button></div>);
}export default App;

在这个示例中,我们使用了React的useState Hook来管理计数器的值。当点击按钮时,会触发increment函数,通过setCount更新计数器的值。React会自动将新的虚拟DOM与旧的虚拟DOM进行对比,只更新需要改变的部分,从而提高了性能。

9. react常⻅的通信⽅式

在React中,常见的通信方式有以下几种:

  1. 父子组件通信:父组件向子组件传递数据,可以通过props进行传递。子组件向父组件传递数据,可以通过回调函数或者使用context实现。

  2. 跨层级组件通信:可以使用context或者状态管理库(如Redux、MobX)来实现跨层级的组件通信。

  3. 同层级组件通信:可以使用事件总线(Event Bus)或者状态管理库(如Redux、MobX)来实现同层级的组件通信。

以下是一个简单的父子组件通信的代码示例:

import React, { useState } from 'react';function ChildComponent(props) {const [inputValue, setInputValue] = useState('');const handleChange = (e) => {setInputValue(e.target.value);props.onChildValueChange(e.target.value);};return (<div><input type="text" value={inputValue} onChange={handleChange} /></div>);
}function ParentComponent() {const [parentValue, setParentValue] = useState('');const handleChildValueChange = (value) => {setParentValue(value);};return (<div><p>Parent Value: {parentValue}</p><ChildComponent onChildValueChange={handleChildValueChange} /></div>);
}export default ParentComponent;

在这个示例中,父组件ParentComponent向子组件ChildComponent传递了一个回调函数handleChildValueChange,子组件通过调用这个回调函数将输入框的值传递给父组件。

10. redux整体的⼯作流程

Redux是一个用于管理JavaScript应用程序状态的库,它遵循函数式编程的思想,使得状态管理变得更加简单、可预测。Redux的整体工作流程如下:

在这里插入图片描述

  1. 首先,用户通过View触发一个Action。
  2. 然后,Dispatcher接收到这个Action,并将其分发给Store。
  3. Store接收到Action后,会调用Reducer函数,传入当前的State和收到的Action。
  4. Reducer函数根据Action的类型和负载,返回一个新的State。
  5. Store将新的State替换旧的State,并将新的State传递给View。
  6. View根据新的State更新界面。

以下是一个简化版的Redux工作流程代码示例:

// 定义Action类型
const INCREMENT = 'INCREMENT';// 定义Action创建函数
function increment(value) {return {type: INCREMENT,value: value};
}// 定义Reducer函数
function counter(state = 0, action) {switch (action.type) {case INCREMENT:return state + action.value;default:return state;}
}// 创建Store
const store = createStore(counter);// 订阅Store的更新
store.subscribe(() => {console.log('Current state:', store.getState());
});// 触发Action
store.dispatch(increment(1)); // 输出:Current state: 1
store.dispatch(increment(1)); // 输出:Current state: 2

在这个示例中,我们定义了一个简单的计数器应用。当触发INCREMENT类型的Action时,Reducer函数会根据Action的负载值更新State,然后Store将新的State传递给View(这里是控制台输出)。

私信【学习】即可获取前端资料 都整理好啦!!!

在这里插入图片描述

相关文章:

5.9号模拟前端面试10问

5.9号模拟前端面试10问 1.html语义化的理解 HTML语义化是指使用具有明确含义的HTML标签来描述内容&#xff0c;而不仅仅是使用<div>和<span>等通用容器标签。语义化的HTML代码更易于阅读和维护&#xff0c;同时也有助于搜索引擎优化&#xff08;SEO&#xff09;。…...

vue3 JSX的使用与警告【JSX 元素隐式具有类型 “any“,因为不存在接口 “JSX.IntrinsicElements“】解决办法

一、安装 pnpm i vitejs/plugin-vue-jsx -D 二、配置 1、tsconfig.json "compilerOptions":{"jsx":"preserve" } 2、vite.config.ts import VueJsx from "vitejs/plugin-vue-jsx"...plugin:[vue(),VueJsx() ] 三、简单使用案例…...

一、计算机基础(Java零基础一)

&#x1f33b;&#x1f33b;目录 一、&#x1f33b;&#x1f33b;剖析学习Java前的疑问&#x1f33b;&#x1f33b;1.1 零基础学习编程1.2 英语不好能学吗&#xff1f;1.3 理解慢能学好吗&#xff1f;1.4 现在学Java晚吗&#xff1f;1.5 Java 和 Python 还有 Go 的选择1.6 Java…...

德国著名自动化公司Festo设计了一款仿生蜜蜂,仅重34g,支持多只蜜蜂编队飞行!...

德国著名的气动元件研发及自动化解决方案供应商Festo公司近日展示了一款仿生蜜蜂&#xff08;BionicBee&#xff09;&#xff0c;重量只有34g&#xff0c;却完全可以实现自主飞行&#xff0c;还支持多只相同的蜜蜂机器人编队飞行。 BionicBee 重约 34 克&#xff0c;长 22 厘米…...

折腾记:C++用开源库Snap7通过S7协议连接西门子PLC

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 不是教程&#xff0c;是避坑指…...

Android studio 新版本 NewUI toolbar显示快捷按钮

新版本的Android studio 启用新的界面&#xff0c;以前许多快捷按键位置有变化 文章目录 设置始终显示主菜单设置ToolBar快捷按钮显示设置右下角显示分支 设置始终显示主菜单 原本要点击左上角几个横向才显示的菜单 设置始终显示&#xff0c;View -> Appearance -> Mai…...

辛普森公式求函数的近似积分【通用计算】

利用辛普森公式可以近似求出复杂函数的积分值&#xff0c;公式如下&#xff1a; ∫ a b f ( x ) d x ≈ h 3 [ y 0 y 2 n − 1 4 ( ∑ i 1 n − 1 y 2 i − 1 ) ∑ i 1 n − 1 y 2 i ] \int_{a}^{b} f(x) dx \approx \frac{h}{3}\left[ y_0 y_{2n-1} 4(\sum\limits_{i1…...

即插即用 | YOLOv8热力图可视化方法详解,揭秘AI如何「看」世界!【附完整源码】

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…...

多线程学习D10 收尾了应该

线程安全集合类概述 重点介绍java.util.concurrent.* 下的线程安全集合类&#xff0c;可以发现它们有规律&#xff0c;里面包含三类关键词&#xff1a;Blocking、CopyOnWrite、Concurrent Blocking 大部分实现基于锁&#xff0c;并提供用来阻塞的方法 CopyOnWrite 之类容器修改…...

ai可以做思维导图吗?当然是可以的!

ai可以做思维导图吗&#xff1f;在快节奏的现代生活中&#xff0c;思维导图作为一种高效的信息组织和表达工具&#xff0c;越来越受到人们的青睐。随着人工智能&#xff08;AI&#xff09;技术的不断发展&#xff0c;AI思维导图软件也应运而生&#xff0c;它们不仅能够帮助用户…...

景源畅信数字:抖音小店的入住门槛大不大?

近年来&#xff0c;随着短视频平台的崛起&#xff0c;抖音小店逐渐成为了众多商家和创业者关注的焦点。那么&#xff0c;抖音小店的入住门槛究竟大不大呢?本文将从四个方面对这一问题进行详细阐述。 一、注册流程 抖音小店的注册流程相对简单&#xff0c;只需按照官方指引完成…...

鸿蒙开发-ArkTS语言-容器-非线性容器

鸿蒙开发-UI-web 鸿蒙开发-UI-web-页面 鸿蒙开发-ArkTS语言-基础类库 鸿蒙开发-ArkTS语言-并发 鸿蒙开发-ArkTS语言-并发-案例 鸿蒙开发-ArkTS语言-容器 文章目录 前言 一、非线性容器 1.HashMap 2.HashSet 3.TreeMap 4.TreeSet 5.LightWeightMap 6.LightWeightSet 7.P…...

【C语言】指针篇- 深度解析Sizeof和Strlen:热门面试题探究(5/5)

&#x1f308;个人主页&#xff1a;是店小二呀 &#x1f308;C语言笔记专栏&#xff1a;C语言笔记 &#x1f308;C笔记专栏&#xff1a; C笔记 &#x1f308;喜欢的诗句:无人扶我青云志 我自踏雪至山巅 文章目录 一、简单介绍Sizeof和Strlen1.1 Sizeof1.2 Strlen函数1.3 Sie…...

【设计模式】单例模式的前世今生

文章目录 引言简介起航&#xff01;向“确保某个类在系统中只有一个实例”进发 ⛵️Lazy SingletonDouble-checked locking&#xff08;DCL&#xff09; SingletonVolatile SingletonAtomic SingletonMeyers Singleton 附&#xff1a;C静态对象的初始化 引言 说起单例模式&…...

厦门网上在线教育系统,线下老师怎么转型到线上网上授课?

现在很多 线下老师都想转到线上做网课&#xff0c;但是在转线上过程中会出现很多问题&#xff0c;很多人都不知道怎么开始&#xff0c;今天小编和大家说一下要注意的。 一、你要有一套适合线上的教学视频 首先你要准备做的课程内容是什么&#xff0c;怎么讲&#xff0c;讲什么&…...

Spring底层入门(九)

boot的执行流程分为构造SpringApplication对象、调用run方法两部分 1、Spring Boot 执行流程-构造 通常我们会在SpringBoot的主启动类中写以下的代码&#xff1a; 参数一是当前类的字节码&#xff0c;参数二是main的args参数。 public class StartApplication {public static…...

掌握Android Fragment开发之魂:Fragment的深度解析(下)

在上一篇文章中&#xff0c;我们深入探讨了Fragment 通信&#xff0c;包含Fragment 向 Activity 传递数据、Activity 向 Fragment 传递数据、Fragment 之间的通信方式。感兴趣的朋友&#xff0c;请前往查阅&#xff1a; 掌握Android Fragment开发之魂&#xff1a;Fragment的深度…...

小巧简单实用的Linux端口转发工具Rinetd

Linux下实现端口转发有很多种方法&#xff0c;尤其是在可以联网的情况下&#xff0c;更是容易。最近在资源受限的定制系统中&#xff0c;找到一个方便离线安装和使用的端口转发工具Rinetd&#xff0c;安装包仅几十K&#xff0c;而且有很多版本的Linux发行系统的支持。 1、安装…...

HackBar 新手使用教程(入门)

啥是Hackbar&#xff1f; Hackbar是一个Firefox 的插件,它的功能类似于地址栏,但是它里面的数据不受服务器的相应触发的重定向等其它变化的影响。 有网址的载入于访问,联合查询,各种编码,数据加密功能。 这个Hackbar可以帮助你在测试SQL注入,XSS漏洞和网站的安全性,主要是帮助…...

<Linux> 权限

目录 权限人员相对于文件来说的分类更改权限文件的拥有者与所属组umask粘滞位 权限 权限是操作系统用来限制对资源访问的机制&#xff0c;权限一般分为读、写、执行。系统中的每个文件都拥有特定的权限、所属用户及所属组&#xff0c;通过这样的机制来限制哪些用户、哪些组可以…...

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…...

conda相比python好处

Conda 作为 Python 的环境和包管理工具&#xff0c;相比原生 Python 生态&#xff08;如 pip 虚拟环境&#xff09;有许多独特优势&#xff0c;尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处&#xff1a; 一、一站式环境管理&#xff1a…...

基于大模型的 UI 自动化系统

基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...

可靠性+灵活性:电力载波技术在楼宇自控中的核心价值

可靠性灵活性&#xff1a;电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中&#xff0c;电力载波技术&#xff08;PLC&#xff09;凭借其独特的优势&#xff0c;正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据&#xff0c;无需额外布…...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!

5月28日&#xff0c;中天合创屋面分布式光伏发电项目顺利并网发电&#xff0c;该项目位于内蒙古自治区鄂尔多斯市乌审旗&#xff0c;项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站&#xff0c;总装机容量为9.96MWp。 项目投运后&#xff0c;每年可节约标煤3670…...

C++中string流知识详解和示例

一、概览与类体系 C 提供三种基于内存字符串的流&#xff0c;定义在 <sstream> 中&#xff1a; std::istringstream&#xff1a;输入流&#xff0c;从已有字符串中读取并解析。std::ostringstream&#xff1a;输出流&#xff0c;向内部缓冲区写入内容&#xff0c;最终取…...

音视频——I2S 协议详解

I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议&#xff0c;专门用于在数字音频设备之间传输数字音频数据。它由飞利浦&#xff08;Philips&#xff09;公司开发&#xff0c;以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...

【C++进阶篇】智能指针

C内存管理终极指南&#xff1a;智能指针从入门到源码剖析 一. 智能指针1.1 auto_ptr1.2 unique_ptr1.3 shared_ptr1.4 make_shared 二. 原理三. shared_ptr循环引用问题三. 线程安全问题四. 内存泄漏4.1 什么是内存泄漏4.2 危害4.3 避免内存泄漏 五. 最后 一. 智能指针 智能指…...

JS红宝书笔记 - 3.3 变量

要定义变量&#xff0c;可以使用var操作符&#xff0c;后跟变量名 ES实现变量初始化&#xff0c;因此可以同时定义变量并设置它的值 使用var操作符定义的变量会成为包含它的函数的局部变量。 在函数内定义变量时省略var操作符&#xff0c;可以创建一个全局变量 如果需要定义…...

linux设备重启后时间与网络时间不同步怎么解决?

linux设备重启后时间与网络时间不同步怎么解决&#xff1f; 设备只要一重启&#xff0c;时间又错了/偏了&#xff0c;明明刚刚对时还是对的&#xff01; 这在物联网、嵌入式开发环境特别常见&#xff0c;尤其是开发板、树莓派、rk3588 这类设备。 解决方法&#xff1a; 加硬件…...