zoukankan      html  css  js  c++  java
  • 撩课-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中的“闭包”是什么?请举一个例子?

    闭包是一个可以访问外部(封闭)函数作用域链中的变量的内部函数。
    
    闭包可以访问三种范围中的变量:
    
    这三个范围具体为:
    (1)自己范围内的变量,
    (2)封闭函数范围内的变量,以及
    (3)全局变量。
    
    下面是一个简单的例子:
    
    var globalVar = "xyz";
    
    (function outerFunc(outerArg) {
      var outerVar = 'a';
    
      (function innerFunc(innerArg) {
        var innerVar = 'b';
    
        console.log(
          "outerArg = " + outerArg + "
    " +
          "innerArg = " + innerArg + "
    " +
          "outerVar = " + outerVar + "
    " +
          "innerVar = " + innerVar + "
    " +
          "globalVar = " + globalVar);
    
      })(456);
    })(123);
    
    在上面的例子中,来自于 innerFunc, 
    outerFunc和全局命名空间的变量都在 innerFunc的范围内。
    因此,上面的代码将输出如下:
    
    outerArg = 123
    innerArg = 456
    outerVar = a
    innerVar = b
    globalVar = xyz
     
     
  • 相关阅读:
    最长上升序列,首尾连接
    带权并查集&&并查集
    开发者的小天地-1
    Binary Tree Maximum Path Sum
    Linked List Cycle II
    动归熟手题单
    java 正则表达式-忽略大小写与多行匹配
    KO之tab栏切换
    Vue中通过属性绑定为元素绑定style
    Vue中通过属性绑定为元素设置class
  • 原文地址:https://www.cnblogs.com/gxq666/p/10204303.html
Copyright © 2011-2022 走看看