Web前端开发工程师面试时有哪些常见面试题?_惠州前端培训学校
作者:hz_admin01发布时间:2022-04-30分类:前端开发专业浏览:1146
Web前端开发工程师面试时有哪些常见面试题?接下来跟着惠州北大青鸟老师一起来了解一下,希望对大家有帮助。
一、MySQL数据库
1. MySQL中varchar与char的区别以及varchar(50)中的50代表的涵义?
答案:
Varchar是变长字符串,最多存储的大小是65535字节,查询速度相对较慢;Char 是定常字符串,最多存储的大小是255字节,查询速度相对较快;
varchar(50)表示:Mysql4.0 表示存放50个字节,5.0存放50个字符。
2. 简述浏览器打开www.codeboy.com显示页面,中间都经过哪些过程?
答案:
向DNS服务器获取域名对应的IP地址并返回浏览器,通过IP地址向Web服务器发请求,Web服务器从文件服务器获取网页中所需要的文件,从数据库服务器获取网页中所需要的数据,最后讲完整的网页相应给浏览器。
3. 如何解决MySQL中存储中文乱码问题?
答案:
脚本文件采用UTF8编码
客户端连接数据库使用UTF8编码
服务器端创建数据库使用UTF8编码
4.Float和Double的区别是什么?
答案:
FLOAT(单精度浮点数)类型 数据可以存储至多8位十进制数,并在内存中占4字节。
DOUBLE(双精度浮点数)类型 数据可以存储至多18位十进制数,并在内存中占8字节。
5. 把数据id等于1的名字oldboy更改为oldgirl?
答案:
update test set name='oldgirl' where id=1;
6.如何登录mysql数据?
答案:
mysql -uroot。
二、JS基础
1. continue和 break有什么区别?
答案:
break和continue都是用来控制循环结构的:
break终止循环,跳出循环体执行循环后面的语句。
continue跳过本次循环,执行下一次循环。
2. i++和++i的区别?
答案:
i++ :先用i值后加1,
++i :先加1后用i值,
计算:var n=5; 求 var num=n++ + ++n + n++ + ++n+n; //37
3. JavaScript都有哪些数据类型?
答案:
原始类型:数值型/字符串型/布尔型/undefined/null
引用类型:对象
4. 自调用函数是什么?用于什么地方?
答案:立即执行的函数。 (function(){ //函数体 })();
用于创建一个局部作用域。
5. slice和splice有什么区别?
答案:
slice截取子数组 ,从指定的数组中,截取几个连续的元素组成一个新数组
splice允许从指定数组中,删除一部分元素,同时再添加另一部分元素
6. typeof返回的类型有哪些?
答案:
number、string 、boolean 、undefined 、object 、function
ex:
var arr=[1,2,3,4,5];
console.log(typeof(arr)); //object
function myDemo(){
return function test(){};
}
console.log(typeof(myDemo())); //function
7. 取 1~11之间的随机数 (即包括1不包括11)?
答案:
Math.floor(Math.random()*10+1)
parseInt (Math.random()*10+1)
8. 什么是变量声明提前?
答案:
使用var关键字声明的变量,会将声明提升到所在作用域的最前边。。
9. push、pop、shift和unshift 区别?
答案:
这两组同为对数组的操作,并且会改变数组的本身的长度及内容。
不同的是push()、pop() 是从数组的尾部进行增减,unshift()、shift() 是从数组的头部进行增减。。
10. 例举4种强制类型转换和3种隐式类型转换?
答案:
强制转换:parseInt/parseFloat/Number/toString
隐式转换:
字符串+数值 数值转字符串
数值+布尔型 布尔型中true转为1,false转为0
字符串+布尔型 布尔型转为字符串。
11. 函数声明与函数表达式的区别?
答案:
相同点:两者都可以创建函数。
不同点:函数声明可以存在函数提升(前),函数表达式不存在函数提升(前)。
//函数声明
function myFunction(){
function innerFunction() {}
}
//以下为函数表达式
var myFunc = function(){};
myFunc(function(){
return function(){};
} );
12. 请指出JavaScript宿主对象和原生对象的区别?
答案:
宿主对象:指JavaScript解释器提供的对象,由解释器厂家自定义并提供实现,不同的解释器提供的扩展对象存在较大的差异(DOM和BOM对象)。
原生对象:JavaScript语言本身预定义的对象,在ECMAScript标准中定义,由所有的解释器厂家来提供具体实现(Array,Date,Math,Number,String,Boolean等)。
13. js中有哪些内置函数?
答案:Object,Array, Boolean, Number, String, Function, Date, Math, RegExp, Error, Global
14.列举出获取日期相关函数
答案:
console.log(Date.now()); // 返回当前日期和时间'1970/01/01 00:00:00'之间的毫秒值
var dt = newDate(); // 获取当前时间---年 月 日 时分 秒
console.log(dt.getTime()); //返回当前日期和时间'1970/01/01 00:00:00'之间的毫秒值
console.log(dt.getFullYear()); // 年份
console.log(dt.getMonth()+1); // 月份(0-11)
console.log(dt.getDate()); // 日期(0/1-31)
console.log(dt.getDay()); //星期(0-6)
console.log(dt.getHours()); // 小时(0-23)
console.log(dt.getMinutes()); // 分钟(0-59)console.log(dt.getMilliseconds); // 返回毫秒(0-999)console.log(dt.getSeconds()); // 秒(0-59)
15.Math相关函数
答案:
Math.random()- 返回 0 ~ 1 之间的随机数
Math.abs(x) -返回数的绝对值
Math.ceil(x)- 向上取整
Math.floor(x)- 向下取整
Math.round() 四舍五入
Math.max() 和 Max.min() 获取一组数据中的最大值和最小值
Math.PI 获取圆周率π 的值Math.pow() 获取一个值的多少次幂
Math.sqrt() 对数值开方
Math.pow(10,2) = 100;
Math.sqrt(100) = 10;
16.null和undefined的区别?
答案:
undefined是访问一个未初始化的变量时返回的值,
null是访问一个尚不存在的对象时所返回的值。因此,可以把undefined看作是空的变量,而null看作是空的对象。
17.==和===有什么不同?
答案:
== 抽象相等,比较时,会先进行类型转换,然后再比较值;
===严格相等,判断两个值相等同时数据类型也得相同。
18.setTimeout和setInterval的区别是什么?
答案:
二者都是用来设置定时操作的。
setTimeout: 设置一个定时器,在定时器到期后执行一次函数或代码段
setInterval: 设置一个定时器,以固定的时间间隔重复调用一个函数或者代码段
19. 请说出以下代码执行结果
for (var i = 0; i < 3; i++)
{
setTimeout(function() {
console.log(i);
}, 0);
console.log(i);
}
答案:0 1 23 3 3,执行过程如下
var i = 0;
console.log(i); i++;
console.log(i); i++;
console.log(i);i++;
setTimeout(function() {
console.log(i);
}, 0);
setTimeout(function() {
console.log(i);
}, 0);
setTimeout(function() {
console.log(i);
}, 0); //输出 0 1 2 3 3 3
20. 请说出(true+flase)>2+true的执行结果
答案:false
21. 当前代码块输出结果是什么?
var z=10;
function foo(){console.log(z);}
(function(funArg){var z=20;funArg();})(foo);
答案:10,自调用函数。
22. setTimeout(function(){},10)表示什么意思?
答案:每隔10毫秒调用一次函数。
23. 程序中捕获异常的方法?
答案:
try{
}catch(e){
}finally{
}
24. 以下代码执行结果?
var uname = 'jack'
function change() {
alert(uname) // ?
var uname = 'lily'
alert(uname) //?
}
change()
答案:undefined lily
25. 如何使用npm下载express模块?
答案:npm install express
26. split和join的区别?
答案:split()将字符串按照指定的字符分割成一个数组,并返回
join()将数组用指定的字符连接成一个字符串,并返回
27. 看下列代码会有什么样的输出?
var foo ="11"+2-"1";
console.log(foo);
console.log(typeof foo);
答案:111 number
28. foo = foo||bar ,这行代码是什么意思?为什么要这样写?
答案:这种写法称之为短路表达式
相当于:
var foo;
if(foo){
foo=foo;
}else{
foo=bar;
}
常用于函数参数的空判断
29. 用js实现随机选取10–100之间的10个数字,存入一个数组,并排序
答案:
function getRandom(istart, iend){
var iChoice = iend -istart +1;
returnMath.floor(Math.random() * iChoice+ istart);
}
var iArray = [];
for(var i=0; i<10; i++)
{
var result= getRandom(10,100);
iArray.push(result);
}
iArray.sort();
30. 如何获取javascript三个数中的最大值和最小值?
答案:Math.max(a,b,c);//最大值
Math.min(a,b,c)//最小值
31. 实现冒泡排序?
vararray = [5, 4, 3, 2, 1];
vartemp = 0;
for(var i = 0;
i <array.length; i++){
for(var j = 0; j <array.length - i; j++){
if(array[j] > array[j + 1]){
temp= array[j + 1];
array[j+ 1] = array[j];
array[j]= temp;
}
}
三、NODEJS
1. 同步和异步有何区别?
答案:
同步:指发送一个请求,需要等待返回,然后才能够发送下一个请求,有等待过程(在一个任务进行中时不能开启其他的任务)。
异步:指发送一个请求,不需要等待返回,随时可以再发送下一个请求,即不需要等待(在一个任务进行中时可以开启其他的任务)。
2. NodeJS中有哪些类型模块,文件操作用哪一个模块?
答案:
模块类型:核心模块、自定义模块、第三方模块。
文件操作:fs模块
3. 对NodeJS的优点和缺点提出自己的看法?
答案:CPU密集型任务的特点是进行大量的计算,消耗CPU资源,比如计算圆周率(上千位)、对视频进行编码等, 全靠CPU的运算能力 (一般用C语言,java)IO(Input / Output)密集型任务,这类任务的特点是CPU消耗很少,大部分时间都在等待IO操作。常见的大部分任务都是IO密集型任务,比如Web应用(一般用脚本语言:python/Nodejs)。Nodejs设计思想中以事件驱动、异步、非堵塞I/O密集型为核心,他提供的大多数api都是基于事件的、异步的风格。所以非常适合处理高并发请求。此外,与Node服务器交互的客户端代码是由js语言编写的,因此客户端和服务器端都用同一种语言编写,减少了成本。
4. 使用NodeJS完成登录功能(编写HTML页面和路由接口中的代码)?
答案:
HTML页面:
<form method="post" action="/user/login">
用户:<input type="text" name="uname"><br>
密码:<input type="text" name="upwd"> <br>
<input type="submit" >
</form>
user.js路由
const express=require('express');
const pool=require('../pool.js');
var router=express.Router();
router.post('/login',(req,res)=>{
var obj=req.body;
var $uname=obj.uname;
if(!$uname){
res.send({code:401,msg:'uname required'});
return;
}
var $upwd=obj.upwd;
if(!$upwd){
res.send({code:402,msg:'upwd required'});
return;
}
var sql='SELECT * FROM xz_user WHERE uname=?AND upwd=?';
pool.query(sql,[$uname,$upwd],(err,result)=>{
if(err) throw err;
if(result.length>0){
res.send({code:200,msg:'login success'});
}else{
res.send({code:301,msg:'login error'});}
});
});
//路由器导出
module.exports=router;
5. 什么是Nodejs?
Nodejs是一个JavaScript的运行环境,是一个服务器端的“JavaScript解释器”,用于方便高效地搭建一些响应速度快、易于扩展的网络应用。它采用事件驱动、异步编程,为网络服务而设计
6. nodejs适用于哪些地方?
高并发、聊天、实时消息推送
7. npm是什么?
npm是nodejs包管理和分发的工具,用于管理node包。如安装、卸载、发布、查看等.
8. npm的好处是什么
通过npm,可以安装和管理项目的依赖,且可以指明依赖项的具体版本号。
9. Node.js中导入模块和导入js文件写法上有什么区别?
nodejs引入模块,直接使用名字导入即可
const express = require("express");
导入js文件,需要使用文件的路径,如:
const student = require("./pool.js");
10. console有哪些常用方法?
console.log/info/error/warn/time/timeEnd
11. express response有哪些常用方法?
o res.download() 弹出文件下载
o res.end() 结束response
o res.json() 返回json
o res.jsonp() 返回jsonp
o res.redirect() 重定向请求
o res.render() 渲染模板
o res.send() 返回多种形式数据
o res.sendFile 返回文件
o res.sendStatus() 返回状
12. node中的Buffer如何应用??
Buffer是用来处理二进制数据的,比如图片,mp3,数据库文件等.Buffer支持各种编码解码,二进制字符串互转
13. 实现一个简单的http服务器?
var http = require('http'); //加载http模块
var server=http.createServer(function(req, res) {
res.writeHead(200,{'Content-Type': 'text/html'});
res.write('hello world');
res.end(); //结束输出流
});
server.listen(3000);
想学前端的同学们,可以来惠州北大青鸟新方舟校区详细了解。
标签:惠州前端培训学校惠州前端基础惠州前端培训北大青鸟IT计算机学校北大青鸟IT软件学校前端北大青鸟IT学校惠州北大青鸟北大青鸟
- 前端开发专业排行
- 标签列表
-
- Java (3694)
- 北大青鸟 (3713)
- 软件开发 (3613)
- JAVA (3413)
- UI设计入门 (2093)
- 惠州北大青鸟 (4375)
- 惠州IT培训 (2558)
- UI设计培训 (2090)
- 惠州UI设计培训 (2095)
- 惠州UI设计培训学校 (2090)
- 惠州计算机软件培训 (6260)
- 惠州计算件软件开发 (6260)
- 惠州计算机软件基础 (6261)
- 惠州计算机JAVA培训 (3574)
- 惠州计算机Java软件开发 (3620)
- 惠州计算机JAVA软件开发 (4645)
- 惠州计算机JAVA软件开发学校 (3338)
- 惠州计算机Java软件开发培训 (3338)
- 北大青鸟IT计算机学校 (5048)
- 北大青鸟IT软件学校 (5062)
- 北大青鸟IT学校 (5059)
- 惠州计算机UI设计软件开发 (2088)
- UI设计基础教程 (2088)
- UI设计是什么 (2088)
- UI设计教程 (2088)
- 网站分类
-
- 计算机教程
- 计算机入门
- 职业学校
- 新闻动态
- 专业课程
- 热门技术
- SEO
- 培训教程
- windows
- linux教程
- 系统集成
- 网站开发
- Html5
- 办公软件
- 师资力量
- 热点问答
- 联系我们
- 计算机学校
- 惠州计算机学校
- 河源计算机学校
- 广州计算机学校
- 深圳计算机学校
- 湛江计算机学校
- 佛山计算机学校
- IT计算机培训信息
- 设计专业
- UI
- 影视特效
- 游戏动漫设计
- Photoshop
- AI设计
- 软件教程
- Java技术
- C语言/C++语言培训
- C#
- Python技术
- PHP
- 数据库
- SQL Server
- 网络教程
- 网络安全
- 网络营销
- 软件专业
- 大数据专业
- 前端开发专业
- 软件测试专业
- Python专业
- 软件实施
- 珠海计算机学校
- 初中生学什么好
- 计算机认证
- 文章归档
-
- 2024年11月 (14)
- 2024年10月 (32)
- 2024年9月 (29)
- 2024年8月 (68)
- 2024年7月 (59)
- 2024年6月 (43)
- 2024年5月 (48)
- 2024年4月 (80)
- 2024年3月 (65)
- 2024年2月 (54)
- 2024年1月 (25)
- 2023年12月 (12)
- 2023年11月 (73)
- 2023年10月 (134)
- 2023年9月 (34)
- 2023年8月 (3)
- 2023年7月 (3)
- 2023年6月 (12)
- 2023年5月 (30)
- 2023年4月 (72)
- 2023年3月 (11)
- 2023年2月 (34)
- 2023年1月 (37)
- 2022年12月 (78)
- 2022年11月 (359)
- 2022年6月 (1193)
- 2022年5月 (570)
- 2022年4月 (1567)
- 2022年3月 (982)
- 2022年2月 (54)
- 2022年1月 (182)
- 2021年9月 (308)
- 2021年8月 (1704)
- 2021年7月 (2423)
- 2021年6月 (1806)
- 2021年5月 (1569)
- 2021年4月 (1380)
- 2021年3月 (1255)
- 2021年2月 (709)
- 2021年1月 (1521)
- 2020年12月 (3626)
- 2020年11月 (1646)
- 2020年10月 (1046)
- 2020年9月 (592)
- 最近发表
-
- 清远信息:2024年广清杯清远南粤家政技能大赛举行决赛|||计算机培训机构
- 汕尾信息:陈良川带队到汕尾技师学院调研|||计算机职业技能培训班
- 东莞信息:凤岗凤岗镇组织召开社保参保缴费及劳动用工政策宣讲会|||计算机软件培训学校
- 阳江信息:2024年度注册城乡规划师职业资格考试的合格标准是怎样的?|||计算机软件培训学校
- 阳江信息:职业技能提升补贴对象有哪些?|||大学生计算机培训学校
- 清远信息:清远市首家社保服务合作网点在清城区举办启动仪式|||计算机职业技能培训班
- 汕头信息:招聘658名中高端人才!2024年汕头市引进中高端人才专场招聘会举行|||北大青鸟计算机培训中心
- 东莞信息:广东省社保智能经办现场会在东莞召开|||大学生计算机培训学校
- 东莞信息:东坑镇举办2024年重点群体系列招聘活动|||计算机职业技能培训班
- 东莞信息:万江万江街道成功举办第四届粤菜师傅烹饪技能竞赛|||广州计算机编程培训