精华内容
下载资源
问答
  • node面试

    千次阅读 2018-06-25 11:28:17
    面试1 https://www.cnblogs.com/meteorcn/p/node_mianshiti_interview_question.html面试2 http://www.bslxx.com/a/mianshiti/tiku/2017/1117/1440.html饿了么面试...
    展开全文
  • Node面试

    千次阅读 2018-10-27 12:01:04
    前端面试题之Node Node的特点有三个:单线程、事件驱动、非阻塞I/O 优点: 因为Node是基于事件驱动和无阻塞的,所以非常适合处理并发请求,因此构建在Node上的代理服务器相比其他技术实现(如Ruby)的服务器表现...

    Node的特点有三个:单线程、事件驱动、非阻塞I/O

    单线程
    像java、PHP等这样的后端语言,都是多线程的,即当有一个请求过来的时候,开启一个CPU,它使计算机能够在同一时间执行多个线程。而node的单线程是指当遇到需要加载数据库、读取磁盘等请求的时候,它会将其放入“队列”中执行,待下一轮事件循环的时候再判断能否执行它的回调函数,若此时它的回调函数需要加载I/O则放入“队列”中,它的特点是线程利用率是100%。

    事件驱动
    举一个通俗点的例子,你在餐厅吃饭,如果当时店内生意比较好,你坐下来,服务员过来招待你,这时,另一桌也刚坐下并呼叫服务员。正常情况下,服务员肯定会想给你个菜单让你自己看看,看好了再叫他,接着去招呼那一桌的客人了,完了再给你端茶什么的。

    这就是事件驱动。通过监听事件的状态变化来做出相应的操作。当你发出一个请求的时候,如果这个请求需要等待,那这个请求便会被放入“队列”中,在处理这个请求的同时,后续的无需请求也在被处理,事件处理结束后,调用请求的回调函数。注:在处理无需等待的事件时,事件循环是暂停的。

    非阻塞I/O
    阻塞I/O就是当用户发一个读取文件描述符的操作的时候,进程就会被阻塞,直到要读取的数据全部准备好返回给用户。那非阻塞I/O呢,就与上面的情况相反,用户发起一个读取文件描述符操作的时,函数立即返回,不作任何等待,进程继续执行。但是程序如何知道要读取的数据已经准备好了呢?最简单的方法就是轮询,即事件循环。

    优点:

    1. 因为Node是基于事件驱动和无阻塞的,所以非常适合处理并发请求,因此构建在Node上的代理服务器相比其他技术实现(如Ruby)的服务器表现要好得多。
    2. 与Node代理服务器交互的客户端代码是由javascript语言编写的,因此客户端和服务器端都用同一种语言编写,这是非常美妙的事情。

    缺点:

    1. Node是一个相对新的开源项目,所以不太稳定,它总是一直在变。
    2. 缺少足够多的第三方库支持。看起来,就像是Ruby/Rails当年的样子(第三方库现在已经很丰富了,所以这个缺点可以说不存在了)。
    展开全文
  • node面试

    千次阅读 2018-01-18 09:28:00
    Node.js面试题列表 什么是错误优先的回调? 错误优先的回调函数用于传递错误和数据,第一个参数始终应该是一个错误对象,用于检查程序是否发生了错误,其余的参数用于传递数据。例如: fs.readFile(filePath, ...

    Node.js面试题列表

    什么是错误优先的回调?
    错误优先的回调函数用于传递错误和数据,第一个参数始终应该是一个错误对象,用于检查程序是否发生了错误,其余的参数用于传递数据。例如:

    fs.readFile(filePath, function(err, data) {  
        if (err) {
            //handle the error
        }
        // use the data object
    });

    解析:这个题目的主要作用在于检查被面试者对于Node中异步操作的一些基本知识的掌握。

    如何避免回调地狱?

    • 模块化:将回调函数分割为独立的函数
    • 使用promises
    • 使用yield
    • 来计算生成器或promise
      解析:这个问题有很多种答案,取决你使用的场景,例如ES6,ES7,或者一些控制流库。

    如何用Node来监听80端口?
    这题有陷阱!在类Unix系统中你不应该尝试去监听80端口,因为这需要超级用户权限。 因此不推荐让你的应用直接监听这个端口。

    目前,如果你一定要让你的应用监听80端口的话,你可以有通过在Node应用的前方再增加一层反向代理 (例如nginx)来实现,如下图所示。否则,建议你直接监听大于1024的端口。
    这里写图片描述

    什么是事件循环?
    Node采用的是单线程的处理机制(所有的I/O请求都采用非阻塞的工作方式),至少从Node.js开发者的角度是这样的。 而在底层,Node.js借助libuv来作为抽象封装层, 从而屏蔽不同操作系统的差异,Node可以借助livuv来来实现多线程。下图表示了Node和libuv的关系。
    这里写图片描述
    Libuv库负责Node API的执行。它将不同的任务分配给不同的线程,形成一个事件循环, 以异步的方式将任务的执行结果返回给V8引擎。可以简单用下面这张图来表示。
    这里写图片描述
    每一个I/O都需要一个回调函数——一旦执行完便推到事件循环上用于执行。 如果你需要更多详细的解释,可以参考这个视频。 你也可以参考这篇文章。

    解释:这用于检查Node.js的底层知识,例如什么是libuv,它的作用是什么。

    哪些工具可以用来保证一致的编程风格?

    • JSLint
    • JSHint
    • ESLint
    • JSCS—-推荐
      在团队开发中,这些工具对于编写代码非常的有帮助,能够帮助团队开发者强制执行规定的风格指南, 还能够通过静态分析捕获常见的错误
      解析:用于被检查者是否有大型项目的开发经验

      运算错误和程序员错误的区别?
      运行错误并不是bug,这是和系统相关的问题,例如请求超时或者硬件故障,而程序员错误就是所谓的bug.
      解析:这个题目和Node关系不大,用于考察面试者的基础知识。

      使用NPM有哪些好处?
      通过NPM,你可以安装和管理项目的依赖,并且能够指明依赖项的具体版本号,对于Node应用开发而言,你可以通过package.json文件来u管理项目信息,配置脚本,以及指明项目依赖的具体版本。
      解析:它能考察面试者使用npm命令的基础知识和Node.js开发的实际经验。

      什么是stub?举个使用场景?
      Stub是用于模拟一个组件或模块的函数或程序。在测试用例中, 简单的说,你可以用Stub去模拟一个方法,从而避免调用真实的方法, 使用Stub你还可以返回虚构的结果。你可以配合断言使用Stub。
      举个例子,在一个读取文件的场景中,当你不想读取一个真正的文件时:

    var fs = require('fs');
    
    var readFileStub = sinon.stub(fs, 'readFile', function (path, cb) {  
        return cb(null, 'filecontent');
    });
    
    expect(readFileStub).to.be.called;  
    readFileStub.restore();
    
    

    在单元测试中:Stub是完全模拟一个外部依赖,而Mock常用来判断测试通过还是失败。

    什么是测试金字塔?对于HTTP API,如何利用测试金字塔?
    当我们在编写测试用例时,底层的单元测试应该远比上层的端到端测试要多。
    这里写图片描述
    当我们谈到HTTP API时,我们可能会涉及到:

    • 有很多针对模型的底层单元测试
    • 但你需要测试模型间如何交互时,需要减少集成测试

      你最喜欢的HTTP框架,并说明原因?
      这题没有唯一的答案。本题主要考察被面试者对于他所使用的Node框架的理解程度, 考察他是否能够给出选择该框架 的理由,优缺点等

    原文地址:https://blog.risingstack.com/node-js-interview-questions/

    展开全文
  • 主要介绍了NodeJS有难度的面试题(能答对几个),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
  • 前端面试题(Node

    千次阅读 2019-05-16 15:12:49
    Node **1. 为什么要用node? ** 特点:简单强大,轻量可扩展.简单体现在node使用的是javascript,json来进行编码,人人都会; 强大体现在非阻塞IO,可以适应分块传输数据,较慢的网络环境,尤其擅长高并发访问;轻量...

    Node

    **1. 为什么要用node? **
    特点:简单强大,轻量可扩展.简单体现在node使用的是javascript,json来进行编码,人人都会;
    强大体现在非阻塞IO,可以适应分块传输数据,较慢的网络环境,尤其擅长高并发访问;轻量体现在node本身既是代码,又是服务器,前后端使用统一语言;可扩展体现在可以轻松应对多实例,多服务器架构,同时有海量的第三方应用组件

    2. node的构架是什么样子的?
    主要分为三层,应用app >> V8及node内置架构 >> 操作系统.
    V8是node运行的环境,可以理解为node虚拟机.node内置架构又可分为三层: 核心模块(javascript实现) >> c++绑定 >> libuv + CAes + http.

    3. node有哪些核心模块?

    EventEmitter, Stream, FS, Net和全局对象
    

    4、node有哪些全局对象?

    process, console, Buffer和exports
    

    5、 process有哪些常用方法?

    process.stdin, process.stdout, process.stderr, process.on, process.env, process.argv, process.arch, process.platform, process.exit
    

    6、console有哪些常用方法?

    console.log/console.info, console.error/console.warning, console.time/console.timeEnd, console.trace, console.table
    

    7、node有哪些定时功能?

    setTimeout/clearTimeout, setInterval/clearInterval, setImmediate/clearImmediate, process.nextTick
    

    8、node中的事件循环是什么样子的?

    总体上执行顺序是:process.nextTick >> setImmidate >> setTimeout/SetInterval
    链接

    9、node中的Buffer如何应用?
    Buffer是用来处理二进制数据的,比如图片,mp3,数据库文件等.Buffer支持各种编码解码,二进制字符串互转.

    **10、什么是EventEmitter? **
    EventEmitternode中一个实现观察者模式的类,主要功能是监听和发射消息,用于处理多模块交互问题.

    11、如何实现一个EventEmitter?
    主要分三步:定义一个子类,调用构造函数,继承EventEmitter
    代码演示

    var util = require(‘util’);
    var EventEmitter = require(‘events’).EventEmitter;

    function MyEmitter() { 
        EventEmitter.call(this); 
    } // 构造函数 
    
    util.inherits(MyEmitter, EventEmitter); // 继承 
    
    var em = new MyEmitter(); 
    em.on('hello', function(data) { 
        console.log('收到事件hello的数据:', data); 
    }); // 接收事件,并打印到控制台 
    em.emit('hello', 'EventEmitter传递消息真方便!');
    

    12、EventEmitter有哪些典型应用?
    1) 模块间传递消息
    2) 回调函数内外传递消息
    3) 处理流数据,因为流是在EventEmitter基础上实现的.
    4) 观察者模式发射触发机制相关应用

    13、怎么捕获EventEmitter的错误事件?
    监听error事件即可.如果有多个EventEmitter,也可以用domain来统一处理错误事件.

    代码演示

    var domain = require('domain'); 
    var myDomain = domain.create(); 
    myDomain.on('error', function(err){ 
        console.log('domain接收到的错误事件:', err); 
    }); // 接收事件并打印 
    myDomain.run(function(){ 
        var emitter1 = new MyEmitter(); 
        emitter1.emit('error', '错误事件来自emitter1'); 
        emitter2 = new MyEmitter(); 
        emitter2.emit('error', '错误事件来自emitter2'); 
    }); 
    

    14、EventEmitter中的newListenser事件有什么用处?
    newListener可以用来做事件机制的反射,特殊应用,事件管理等.当任何on事件添加到EventEmitter时,就会触发newListener事件,基于这种模式,我们可以做很多自定义处理.

    代码演示

    var emitter3 = new MyEmitter();
    emitter3.on('newListener', function(name, listener) {
        console.log("新事件的名字:", name); 
        console.log("新事件的代码:", listener); 
        setTimeout(function(){ console.log("我是自定义延时处理机制"); }, 1000); 
    });
    emitter3.on('hello', function(){
        console.log('hello node'); 
    });
    

    **15、什么是Stream? **
    stream是基于事件EventEmitter的数据管理模式.由各种不同的抽象接口组成,主要包括可写,可读,可读写,可转换等几种类型.

    16、Stream有什么好处?
    非阻塞式数据处理提升效率,片断处理节省内存,管道处理方便可扩展等.

    17、Stream有哪些典型应用?
    文件,网络,数据转换,音频视频等

    18、怎么捕获Stream的错误事件?
    监听error事件,方法同EventEmitter

    **19、有哪些常用Stream,分别什么时候使用? **
    Readable为可被读流,在作为输入数据源时使用;Writable为可被写流,在作为输出源时使用;Duplex为可读写流,它作为输出源接受被写入,同时又作为输入源被后面的流读出.Transform机制和Duplex一样,都是双向流,区别时Transfrom只需要实现一个函数_transfrom(chunk, encoding, callback);Duplex需要分别实现_read(size)函数和_write(chunk, encoding, callback)函数.

    **20、实现一个Writable Stream? **
    三步走:1)构造函数call Writable
    2) 继承Writable 在这里插入代码片
    3) 实现_write(chunk, encoding, callback)函数

    代码演示

    var Writable = require('stream').Writable;
    var util = require('util');
     
    function MyWritable(options) {
        Writable.call(this, options); 
    } // 构造函数 
    util.inherits(MyWritable, Writable); // 继承自Writable 
    MyWritable.prototype._write = function(chunk, encoding, callback) {
        console.log("被写入的数据是:", chunk.toString()); // 此处可对写入的数据进行处理 
        callback(); 
    };
     
    process.stdin.pipe(new MyWritable()); // stdin作为输入源,MyWritable作为输出源
    

    21、内置的fs模块架构是什么样子的?
    fs模块主要由下面几部分组成:
    1) POSIX文件Wrapper,对应于操作系统的原生文件操作
    2) 文件流 fs.createReadStreamfs.createWriteStream
    3) 同步文件读写,fs.readFileSyncfs.writeFileSync
    4) 异步文件读写, fs.readFilefs.writeFile

    **22、读写一个文件有多少种方法? **
    1) POSIX式低层读写
    2) 流式读写
    3) 同步文件读写
    4) 异步文件读写

    23、怎么读取json配置文件?
    第一种是利用node内置的require('data.json')机制,直接得到js对象;
    第二种是读入文件入内容,然后用JSON.parse(content)转换成js对象.二者的区别是require机制情况下,如果多个模块都加载了同一个json文件,那么其中一个改变了js对象,其它跟着改变,这是由node模块的缓存机制造成的,只有一个js模块对象; 第二种方式则可以随意改变加载后的js变量,而且各模块互不影响,因为他们都是独立的,是多个js对象.

    24、fs.watch和fs.watchFile有什么区别,怎么应用?
    fs.watch利用操作系统原生机制来监听,可能不适用网络文件系统; fs.watchFile则是定期检查文件状态变更,适用于网络文件系统,但是相比fs.watch有些慢,因为不是实时机制.

    25、node的网络模块架构是什么样子的?
    node全面支持各种网络服务器和客户端,包括tcp, http/https, tcp, udp, dns, tls/ssl等.

    26、node是怎样支持https,tls的?
    1) openssl生成公钥私钥
    2) 服务器或客户端使用https替代http
    3) 服务器或客户端加载公钥私钥证书

    27、实现一个简单的http服务器?
    思路是加载http模块,创建服务器,监听端口.

    代码演示

    var http = require('http'); // 加载http模块 
    
    http.createServer(function(req, res) { 
        res.writeHead(200, {'Content-Type': 'text/html'}); // 200代表状态成功, 文档类型是给浏览器识别用的 
        res.write('<meta charset="UTF-8"><h1>我是标题啊!</h1><font color="red">这么原生,初级的服务器,下辈子能用着吗?!</font>'); // 返回给客户端的html数据 
        res.end(); // 结束输出流 
    }).listen(3000); // 绑定3ooo, 查看效果请访问 http://localhost:3000 
    

    **28、为什么需要child-process? **
    node是异步非阻塞的,这对高并发非常有效.可是我们还有其它一些常用需求,比如和操作系统shell命令交互,调用可执行文件,创建子进程进行阻塞式访问或高CPU计算等,child-process就是为满足这些需求而生的.child-process顾名思义,就是把node阻塞的工作交给子进程去做.

    29、exec,execFile,spawn和fork都是做什么用的?
    exec可以用操作系统原生的方式执行各种命令,如管道 cat ab.txt | grep hello;
    execFile是执行一个文件;
    spawn是流式和操作系统进行交互;
    fork是两个node程序(javascript)之间时行交互.

    30、实现一个简单的命令行交互程序?
    spawn

    代码演示

    var cp = require('child_process'); 
    
    var child = cp.spawn('echo', ['你好', "钩子"]); // 执行命令 
    child.stdout.pipe(process.stdout); // child.stdout是输入流,process.stdout是输出流 
    // 这句的意思是将子进程的输出作为当前程序的输入流,然后重定向到当前程序的标准输出,即控制台 
    

    **31、两个node程序之间怎样交互? **
    用fork嘛,上面讲过了.原理是子程序用process.on, process.send,父程序里用child.on,child.send进行交互.
    代码演示

    1) fork-parent.js 
    var cp = require('child_process'); 
    var child = cp.fork('./fork-child.js'); 
    child.on('message', function(msg){ 
        console.log('老爸从儿子接受到数据:', msg); 
    }); 
    child.send('我是你爸爸,送关怀来了!'); 
    
    2) fork-child.js 
    process.on('message', function(msg){ 
        console.log("儿子从老爸接收到的数据:", msg); 
        process.send("我不要关怀,我要银民币!"); 
    }); 
    

    **32、怎样让一个js文件变得像linux命令一样可执行? **
    1) 在myCommand.js文件头部加入#!/usr/bin/env node
    2) chmod命令把js文件改为可执行即可
    3) 进入文件目录,命令行输入myComand就是相当于node myComand.js

    33、child-process和process的stdin,stdout,stderror是一样的吗?
    概念都是一样的,输入,输出,错误,都是流.区别是在父程序眼里,子程序的stdout是输入流,stdin是输出流

    34、node中的异步和同步怎么理解
    node是单线程的,异步是通过一次次的循环事件队列来实现的.同步则是说阻塞式的IO,这在高并发环境会是一个很大的性能问题,所以同步一般只在基础框架的启动时使用,用来加载配置文件,初始化程序什么的

    **35、有哪些方法可以进行异步流程的控制? **
    1) 多层嵌套回调
    2) 为每一个回调写单独的函数,函数里边再回调
    3) 用第三方框架比方async, q, promise

    36、怎样绑定node程序到80端口?
    1) sudo
    2) apache/nginx代理
    3) 用操作系统的firewall iptables进行端口重定向

    37、有哪些方法可以让node程序遇到错误后自动重启?
    1) runit
    2) forever
    3) nohup npm start &

    38、怎样充分利用多个CPU?
    一个CPU运行一个node实例

    39、怎样调节node执行单元的内存大小?
    --max-old-space-size--max-new-space-size 来设置 v8 使用内存的上限

    **40、程序总是崩溃,怎样找出问题在哪里? **
    1) node --prof 查看哪些函数调用次数多
    2) memwatchheapdump获得内存快照进行对比,查找内存溢出

    **41、有哪些常用方法可以防止程序崩溃? **
    1) try-catch-finally
    2) EventEmitter/Stream error事件处理
    3) domain统一控制
    4) jshint静态检查
    5) jasmine/mocha进行单元测试

    42、怎样调试node程序?
    node --debug app.jsnode-inspector

    43、async都有哪些常用方法,分别是怎么用?
    async是一个js类库,它的目的是解决js中异常流程难以控制的问题.async不仅适用在node.js里,浏览器中也可以使用.
    1) async.parallel并行执行完多个函数后,调用结束函数

    async.parallel([ 
        function(){ ... }, 
        function(){ ... } 
    ], callback); 
    
    1. async.series串行执行完多个函数后,调用结束函数
    async.series([ 
        function(){ ... }, 
        function(){ ... } 
     ]); 
    
    1. async.waterfall依次执行多个函数,后一个函数以前面函数的结果作为输入参数
    async.waterfall([ 
       function(callback) { 
           callback(null, 'one', 'two'); 
       }, 
       function(arg1, arg2, callback) { 
         // arg1 now equals 'one' and arg2 now equals 'two' 
           callback(null, 'three'); 
       }, 
       function(arg1, callback) { 
           // arg1 now equals 'three' 
           callback(null, 'done'); 
       } 
    ], function (err, result) { 
       // result now equals 'done' 
    }); 
    
    1. async.map异步执行多个数组,返回结果数组
    async.map(['file1','file2','file3'], fs.stat, function(err, results){ 
      // results is now an array of stats for each file 
    }); 
    
    1. async.filter异步过滤多个数组,返回结果数组
    async.filter(['file1','file2','file3'], fs.exists, function(results){ 
      // results now equals an array of the existing files 
    });
    

    44、express项目的目录大致是什么样子的

    app.js, package.json, bin/www, public, routes, views.
    

    45、express常用函数
    express.Router路由组件,app.get路由定向,app.configure配置,app.set设定参数,app.use使用中间件

    46、express中如何获取路由的参数
    /users/:name使用req.params.name来获取;
    req.body.username则是获得表单传入参数username;
    express路由支持常用通配符 ?, +, *, and ()

    47、express response有哪些常用方法
    res.download() 弹出文件下载
    res.end() 结束response
    res.json() 返回json 在这里插入代码片
    res.jsonp() 返回jsonp
    res.redirect() 重定向请求
    res.render() 渲染模板
    res.send() 返回多种形式数据
    res.sendFile 返回文件
    res.sendStatus() 返回状态

    48、mongodb有哪些常用优化措施
    类似传统数据库,索引和分区

    49、mongoose是什么?有支持哪些特性?
    mongoosemongodb的文档映射模型.主要由Schema, ModelInstance三个方面组成.
    Schema就是定义数据类型,
    Model就是把Schemajs类绑定到一起,
    Instance就是一个对象实例.
    常见mongoose操作有,save, update, find. findOne, findById, static方法等

    50、redis支持哪些功能

    set/get, mset/hset/hmset/hmget/hgetall/hkeys, sadd/smembers, publish/subscribe, expire
    

    51、redis最简单的应用

    var redis = require("redis"), 
       client = redis.createClient(); 
    
    client.set("foo_rand000000000000", "some fantastic value"); 
    client.get("foo_rand000000000000", function (err, reply) { 
       console.log(reply.toString()); 
    }); 
    client.end(); 
    

    52、apache,nginx有什么区别?
    二者都是代理服务器,功能类似.
    apache应用简单,相当广泛.
    nginx在分布式,静态转发方面比较有优势

    展开全文
  • 前端面试题整理—Node

    万次阅读 2020-04-08 18:20:09
    1、node有哪些特征,与其他服务器端对比 特征:单线程、事件驱动、非阻塞I/O node 无法直接渲染静态页面,提供静态服务 node 没有根目录的概念 node 必须通过路由程序指定文件才能渲染文件 node 比其他服务端性能更...
  • 15 个常见的 Node.js 面试问题及答案

    千次阅读 2021-02-17 14:40:00
    点击上方“逆锋起笔”,公众号回复编程资源 领取大佬们推荐的学习资料 作者|Juan Cruz Martinez 来源|前端之巅 译者|吴留坡 临阵磨枪,不快也光。对于成功的编程面试来说,...
  • 本项目虽然是基于饿了么Node面试教程而来,但是在此基础上做了拓展,比如在JS基础部分加入了面向对象 原型链等重要知识. 由于原项目包括知识点和常见问题两个部分,我们会先整理知识点部分的文字,再在后面补充常见问题...
  • node升阶段面试50

    千次阅读 2020-04-23 09:09:50
    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。 Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型。 Node 是一个让 JavaScript 运行在服务端的开发平台。 搭建一个简单服务器的步骤? 引入 http...
  • 10个常见的Node.js面试

    千次阅读 2017-12-07 15:23:07
    10个常见的Node.js面试
  • 阿里Node.js面试题集合

    万次阅读 多人点赞 2018-07-10 13:52:27
    前提说明:自己是在北邮...简历说明中侧重讲了关于Node.js的经历,JavaScript轮子的介绍以及一些使用了Node.js技术栈的Web项目。这点对于前端实习也是一个加分项。一面:一面面试官问了大概有4年开发经验(包括了Jav...
  • 从ECMAScript标准,Node.js语法以及NPM模块角度来看,Node.js的发展让人目不暇接,那么面试题也得与时俱进。 问题 什么是错误优先的回调函数? 如何避免回调地狱? 什么是Promise? 用什么工具保证一致的代码...
  • Hi, 欢迎来到 ElemeFE, 如标题所示本教程的目的是教你如何通过饿了么大前端的面试, 职位是 2~3 年经验的 Node.js 服务端程序员, 如果你对这个职位感兴趣或者学习 Node.js 一些进阶的内容, 那么欢迎阅读.
  • node.JS 常见面试

    2018-05-26 17:10:32
    node.js是一款基于浏览器的Js运行平台,内置V8引擎,高效
  • NodeJs(前端面试题整合)

    千次阅读 多人点赞 2020-11-28 16:48:17
    谈谈对Node的理解 Node.js 在浏览器外运行V8 JavaScript引擎,单线程 非阻塞I/O 事件驱动,适应于数据高并发,适合多请求,但不适合高运算,有权限读取操作系统级别的API,npm 仓库,常用框架:Express,koa,Socket.io...
  • nodejs面试总结

    万次阅读 2019-03-26 10:38:48
    一:Node 好处: 处理高并发 事件驱动 轻量 要用于搭建高性能的web服务器,  1. 它是一个Javascript运行环境  2. 依赖于Chrome V8引擎进行代码解释  3. 事件驱动  4. 非阻塞I/O  5. 轻量、可伸缩,适于...
  • Node是搞后端的,不应该被被归为前端,更不应该用前端的观点去理解,去面试node开发人员。所以这份面试题大全,更侧重后端应用与对Node核心的理解。 github地址: ...
  • 在去年底开始换工作,直到现在算是告了一个段落,断断续续的也面试了不少公司,现在回想起来,那段时间经历了被面试官手撕,被笔试题狂怼,悲伤的时候差点留下没技术的泪水。 这篇文章我打算把我找工作遇到的各种...
  • nodejs面试

    万次阅读 2019-06-21 10:39:30
    1、为什么用Nodejs,它有哪些缺点? 事件驱动,通过闭包很容易实现客户端的生命活期。 不用担心多线程,锁,并行计算的问题 V8引擎速度非常快 对于游戏来说,写一遍游戏逻辑代码,前端后端通用 ...
  • nodejs 面试题(个人总结)

    千次阅读 2020-12-02 20:49:46
    Node是一个基于Chrome JavaScript运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用 作为web前端开发人员需要了解一门后台语言 对于前端开发人员nodejs 更容易上手 nodejs有哪些特点 RESTf..
  • Node.JS - 爬虫系统基础教程

    千人学习 2018-06-20 16:20:48
    Node.JS是一套使用JavaScript语言的后台。它执行Javascript的速度非常快,性能非常好。是近几年来火的公司首选后台语言之一,同时也是前后台人员争先恐后学习的后台语言。 网络爬虫(又被称为网页蜘蛛,网络机器人)...
  • 53道常见NodeJS基础面试题(附答案)

    万次阅读 2021-05-22 00:51:09
    点击下方“前端开发博客”关注公众号回复“2”加入前端群说到前端就不得不提到后端,我们给用户展示页面所需的数据正是从后端获取的,所以了解后端的运行原理和技术的实现很有必要。Node. js...
  • Nodejs的高频经典面试题解析

    千次阅读 2020-05-10 19:11:35
    Pug是一款健壮、灵活、功能丰富的HTML模板引擎,专门为 Node.js 平台开发。Pug是由Jade 改名而来。是一种通过缩进(表示标签间的嵌套关系) 的方式来编写代码的过程,在编译的过程中,不需要考虑标签是否闭合的问题...
  • 说到前端就不得不提到后端,我们给用户展示页面所需的数据正是从后端获取的,所以了解后端的运行原理和技术的实现很有必要。Node. js是一个不错的选择,它是基于JavaScript语法的一...
  • 主要总结了几道关于Node.js的面试问题,通过这些问题就来判断一个人的Node.js水平是不太严谨的,但是它能让你对面试者在Node.js上的经验如何有个大概的了解。有需要的朋友可以参考借鉴,下面来一起看看吧。
  • node概览 1. 为什么要用node? 参考答案: 总结起来node有以下几个特点:简单强大,轻量可扩展.简单体现在node使用的是javascript,json来进行编码,人人都会;强大体现在非阻塞IO,可以适应分块传输数据,较慢的...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 81,758
精华内容 32,703
关键字:

node面试