【社招】面试_中科飞思_前端工程师

1 面试信息

面试形式:视频面试

面试时间:2026-03-23 13:00

面试时长:约20分钟

面试职位:前端工程师

2 面试问题

1.介绍下你做的项目,有遇到什么难点,如何解决

2.JavaScript中const、var和let作用域有什么区别

3.跨域问题如何解决

4.有没有用到中间件Redis,介绍一下

5.大学期间做过什么项目


* 面试问题答案整理

1.略

2.(1)作用域差别:var 声明的变量存在函数作用域或全局作用域,它们在整个函数或全局范围内都是可访问的。let 和 const 声明的变量存在块级作用域,它们在声明的块级作用域内有效,即包括 {} 内的代码块。

(2)变量提升:var 声明的变量在作用域内会进行变量提升,即在其作用域内的任何位置都可以访问变量,即使在声明之前也可以访问到,但其值为 undefined。let 和 const 声明的变量不会进行变量提升,它们只能在声明之后的代码中访问。

(3)重复声明:使用 var 声明的变量可以在同一作用域内重复声明,而后面的声明会覆盖前面的声明。使用 let 或 const 声明的变量在同一作用域内不允许重复声明,否则会引发语法错误。

(4)可修改性:使用 var 或 let 声明的变量的值可以被修改。使用 const 声明的变量是常量,其值在声明后不能被修改。尝试修改一个常量会导致运行时错误。

3.当浏览器的请求地址和服务器的接口地址满足"协议、域名、端口"三者中任意一个不同时,就属于跨域请求。为什么浏览器要拦截呢?这是浏览器的"同源策略"在起保护作用,防止恶意网站窃取其他网站的敏感数据。后端解决跨域是最推荐的方式,因为只需要配置一次,所有前端请求都能生效,不用前端做额外处理。

后端解决跨域:

(1)最简洁------单个接口加@CrossOrigin注解

(2)最常用------全局配置类(推荐)

(3)最灵活------过滤器Filter配置

前端解决跨域:

(1)开发环境专用------Vite代理配置(最常用)

(2)生产环境可用------Axios请求拦截器(配合后端)

4.Redis 是一个高性能的开源 NoSQL 数据库,主要用于缓存和快速数据存取。它以键值对的形式存储数据,支持多种数据类型,如字符串、列表、集合、散列和有序集合。

5.略

相关推荐
huabiangaozhi2 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
宝耶2 小时前
Java面试2:final、finally、finalize 的区别?
java·开发语言·面试
umeelove352 小时前
Spring boot整合quartz方法
java·前端·spring boot
小码哥_常2 小时前
Android 开发探秘:View.post()为何能获取View宽高
前端
爱学习的程序媛2 小时前
【Web前端】WebAssembly详解
前端·web·wasm
比昨天多敲两行2 小时前
C++ 继承
开发语言·c++·面试
不会写DN3 小时前
Js常用的字符串处理
开发语言·前端·javascript
晓13133 小时前
第三章 TypeScript 高级类型
前端·javascript·typescript
一勺菠萝丶3 小时前
芋道项目部署时,前端和门户网站如何通过 Nginx 转发后台接口,而不直接暴露后端地址
运维·前端·nginx
黑白两客3 小时前
Vue 缓存机制
前端·vue.js·缓存