撩课-Web大前端每天5道面试题-Day23
1、为什么用Nodejs,它有哪些优缺点?
优点:
事件驱动,通过闭包很容易实现客户端的生命活期。
不用担心多线程,锁,并行计算的问题
V8引擎速度非常快
对于游戏来说,写一遍游戏逻辑代码,前端后端通用
缺点:
nodejs更新很快,可能会出现版本兼容
nodejs还不算成熟,还没有大制作
nodejs不像其他的服务器,对于不同的链接,不支持进程和线程操作
2、什么是错误优先的回调函数?
错误优先(Error-first)的回调函数(Error-First Callback)用于同时返回错误和数据。
第一个参数返回错误,并且验证它是否出错;其他参数返回数据。 fs.readFile(filePath, function(err, data)
{
if (err)
{
// 处理错误
return console.log(err);
}
console.log(data);
});
3、使用NPM有哪些好处?
通过NPM,你可以安装和管理项目的依赖,
并且能够指明依赖项的具体版本号。
对于Node应用开发而言,
你可以通过package.json文件来管理项目信息,
配置脚本,以及指明依赖的具体版本
4、在JavaScript源文件的开头包含 use strict 有什么意义和好处?
对于这个问题,
既简要又最重要的答案是,
use strict 是一种在JavaScript代码运行时自动实行更严格解析和错误处理的方法。
那些被忽略或默默失败了的代码错误,会产生错误或抛出异常。 通常而言,这是一个很好的做法。 严格模式的一些主要优点包括: 使调试更加容易。
那些被忽略或默默失败了的代码错误,会产生错误或抛出异常,
因此尽早提醒你代码中的问题,
你才能更快地指引到它们的源代码。
防止意外的全局变量。 如果没有严格模式,
将值分配给一个未声明的变量会自动创建该名称的全局变量。
这是JavaScript中最常见的错误之一。
在严格模式下,这样做的话会抛出错误。
消除 this 强制。 如果没有严格模式,
引用null或未定义的值到 this 值会自动强制到全局变量。
这可能会导致许多令人头痛的问题和让人恨不得拔自己头发的bug。
在严格模式下,
引用 null或未定义的 this 值会抛出错误。
不允许重复的属性名称或参数值。 当检测到对象
(例如,var object = {foo: "bar", foo: "baz"};)
中重复命名的属性,或检测到函数中
(例如,function foo(val1, val2, val1){})重复命名的参数时,
严格模式会抛出错误,
因此捕捉几乎可以肯定是代码中的bug可以避免浪费大量的跟踪时间。
使eval() 更安全。 在严格模式和非严格模式下,eval() 的行为方式有所不同。
最显而易见的是,在严格模式下,
变量和声明在 eval() 语句内部的函数不会在包含范围内创建
(它们会在非严格模式下的包含范围中被创建,这也是一个常见的问题源)。
在 delete使用无效时抛出错误。 delete操作符(用于从对象中删除属性)不能用在对象不可配置的属性上。
当试图删除一个不可配置的属性时,
非严格代码将默默地失败,
而严格模式将在这样的情况下抛出异常。
5、JavaScript中的“闭包”是什么?请举一个例子?
闭包是一个可以访问外部(封闭)函数作用域链中的变量的内部函数。 闭包可以访问三种范围中的变量: 这三个范围具体为:
()自己范围内的变量,
()封闭函数范围内的变量,以及
()全局变量。 下面是一个简单的例子: var globalVar = "xyz"; (function outerFunc(outerArg) {
var outerVar = 'a'; (function innerFunc(innerArg) {
var innerVar = 'b'; console.log(
"outerArg = " + outerArg + "\n" +
"innerArg = " + innerArg + "\n" +
"outerVar = " + outerVar + "\n" +
"innerVar = " + innerVar + "\n" +
"globalVar = " + globalVar); })();
})(); 在上面的例子中,来自于 innerFunc,
outerFunc和全局命名空间的变量都在 innerFunc的范围内。
因此,上面的代码将输出如下: outerArg =
innerArg =
outerVar = a
innerVar = b
globalVar = xyz
撩课-Web大前端每天5道面试题-Day23的更多相关文章
- 撩课-Web大前端每天5道面试题-Day10
1. px和em的区别? px和em都是长度单位; 区别是: px的值是固定的,指定是多少就是多少, 计算比较容易. em得值不是固定的,并且em会继承父级元素的字体大小. 浏览器的默认字体高都是16 ...
- 撩课-Web大前端每天5道面试题-Day4
1. 如何实现瀑布流? 瀑布流布局的原理: ) 瀑布流布局要求要进行布置的元素等宽, 然后计算元素的宽度, 与浏览器宽度之比,得到需要布置的列数; ) 创建一个数组,长度为列数, 里面的值为已布置元素 ...
- 撩课-Web大前端每天5道面试题-Day1
1. var的变量提升的底层原理是什么? JS引擎的工作方式是: 1) 先解析代码,获取所有被声明的变量: 2)然后在运行.也就是说分为预处理和执行两个阶段. 变量提升:所有变量的声明语句都会被提升到 ...
- 撩课-Web大前端每天5道面试题-Day11
1. 如何手写一个JQ插件? 方式一: $.extend(src) 该方法就是将src合并到JQ的全局对象中去: $.extend({ log: ()=>{alert('撩课itLike');} ...
- 撩课-Web大前端每天5道面试题-Day31
1.web storage和cookie的区别? Web Storage的概念和cookie相似, 区别是它是为了更大容量存储设计的. Cookie的大小是受限的, 并且每次你请求一个新的页面的时候C ...
- 撩课-Web大前端每天5道面试题-Day25
1.web前端开发,如何提高页面性能优化? 内容方面: .减少 HTTP 请求 (Make Fewer HTTP Requests) .减少 DOM 元素数量 (Reduce the Number o ...
- 撩课-Web大前端每天5道面试题-Day7
1. 你能描述一下渐进增强和优雅降级之间的不同吗? 定义: 优雅降级(graceful degradation): 一开始就构建站点的完整功能, 然后针对浏览器测试和修复 渐进增强(progressi ...
- 撩课-Web大前端每天5道面试题-Day30
1.什么叫优雅降级和渐进增强? 优雅降级: Web站点在所有新式浏览器中都能正常工作, 如果用户使用的是老式浏览器, 则代码会针对旧版本的IE进行降级处理了, 使之在旧式浏览器上以某种形式降级体验却不 ...
- 撩课-Web大前端每天5道面试题-Day16
1.for循环中的作用域问题? 写出以下代码输出值,尝试用es5和es6的方式进行改进输出循环中的i值. ; i<=; i++) { setTimeout(function timer() { ...
随机推荐
- poj3070矩阵快速幂求斐波那契数列
Fibonacci Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13172 Accepted: 9368 Desc ...
- svn update 产生Node remains in conflict的问题
输入:sudo svn revert --depth=infinity frontend/web/js/workplace/organization.js 最后在执行 svn up 就ok了
- android应用程序的混淆打包
android应用程序的混淆打包 1 . 在工程文件project.properties中加入下proguard.config=proguard.cfg , 如下所示: target=android- ...
- apache2.4脚本一键安装(linux环境)
1.下载apache安装包和相关组件 下载地址:https://pan.baidu.com/s/1o85i6Jw 其中包括 apache安装包:httpd-2.4.29.tar.gz apache安装 ...
- 移动端h5直播项目|html5直播实战开发|h5仿陌陌
最近一些直播.小视频什么的都比较火,像陌陌.抖音.火山短视频… 于是空闲时间自己也利用html5技术也试着倒腾了下直播项目,使用到了h5+css3+iscroll+zepot+swiper+wlsPo ...
- Mac下的paths.d目录神奇用法
首先,这个方法是通过PG的做法学到的,且这个方法只能在Mac下用,在Linux下还真没有这个方法. 这个paths.d的作用很简单,就是在里面创建一个文件,然后写上需要在全局命令行下用到的命令,直接配 ...
- VM下--Linux根分区磁盘扩容
转载请注明源出处:http://www.cnblogs.com/lighten/p/6825938.html 1.缘由 由于需要对虚拟机中的软件进行升级,执行yum update的时候,整个更新包在8 ...
- C/C++ -- Gui编程 -- Qt库的使用 -- Qt5总结
主要变化: 1.与Qt4相比,Qt5可以直接显示中文不需要手工转码2.Qt5模块发生变化,大部分组件并入widgets模块 注意事项:工程文件加一句greaterThan(QT_MAJOR_VERSI ...
- 【软件工程实践】第二次作业:分布式版本控制系统Git的安装与使用
1.下载安装配置用户名和邮箱. 2. 创建工作目录并通过git init命令把这个目录变成Git可以管理的仓库. 3. 在工作目录下准备文本文件,建议下载Notepad++代替记事本. 4. 组合用g ...
- vsts~CI/CD实现自动化编译
打开你的vs online,选择build and release标签,进行自动化编译的开发. 一 新建,选择对应的源代码管理,我们以VSTS-GIT为例 二 选择你的项目所应对的开发框架,如.net ...