Javascript前端经典的面试题及答案前端经典的面试题及答案
前言前言
如果面试题按类型来分,主要涉及到“技术”与“非技术”两大类,技术类别下涉及到的子类别有:
移动 & PC端布局类
JavaScript 核心基础类
衍生框架类
项目应用类
这四大类别的面试题若按出现频率来划分,则面试时 100% 会问到的题型有:“移动端&PC端布局类、JavaScript 核心基础
类”。本次选择这两类中难度更高一些的 “JavaScript 核心基础类” 面试题,进行了分析和解答,供面试前准备。
特别说明:特别说明:
假如你在面试时被这些题型卡住了,就必须正视自己的知识短板,并且要心悦城服的刻苦钻研、直至学会为止!毕竟想要成为
一个合格的 “WEB前端工程师”,掌握以下这些 JavaScript 核心的基础知识,才担得上“合格”这两个字,否则就是“冒牌”的哦~
一、一、JavaScript 的的 typeof 返回哪些数据类型?返回哪些数据类型?
分析:分析:
这道题检验的是 JS 基本功,只要对 typeof 运算符是了解的,就没有太大难度。具体在回答的时候,再结合理论知识和编码过
程中实际情况进行回答即可。另外,考虑到面试时的严谨性, ES2015 中新增的类型也并入回复中。
建议回复:建议回复:
首先,JavaScript 中一共有两大数据类型:
基础类型
引用类型
· 基础类型包括:Number、String、Boolean、Null、Undefined、Symbol(该类型位 ES2015 中新增类型)
· 引用类型包括:Object typeof 运算符把类型信息以字符串形式返回,需要注意的是 typeof 返回的类型和 JavaScript 定义
的类型有细微的差异。 typeof 返回七种可能的值:“number”、“string”、“boolean”、“object”、”symbol”、
“function”和“undefined”。
二、请写出以下代码运算结果:二、请写出以下代码运算结果:
alert(typeof null);
alert(typeof undefined);
alert(typeof NaN);
alert(NaN == undefined);
alert(NaN == NaN);
var str = "123abc";
alert(typeof str++);
alert(str);
分析:分析:
这道题与“题目一”是连环扣,当“题目一”回答完后,通过此题再一次强化运算符和数据类型的基本功。
建议回复:建议回复:
本题主要是考察 typeof 判断值的类型,它们输出的结果依次是:
alert(typeof null); // object
alert(typeof undefined); // undefined
alert(typeof NaN); // number
alert(NaN == undefined); // false
alert(NaN == NaN); // false
var str = "123abc";
alert(typeof str++); // number
alert(str); // NaN
三、例举至少三、例举至少 3 种强制类型转换和种强制类型转换和 2 种隐式类型转换种隐式类型转换?
分析:分析:
类型转换听起来可能有点宽泛,但这道题明确给出了回答的范围。