Nodejs新手必须知道的4个JavaScript概念

54次阅读

共计 4129 个字符,预计需要花费 11 分钟才能阅读完成。

如果只需要知道一种编程语言就可以构建一个全栈的应用程序,是不是特别了不起?Ryan Dahl 为了把这个想法成为现实,创造了 node.js。Node.js 是建立在 Chrome 强劲的 V8 JavaScript 引擎上的服务器端框架。虽然最初是用 C ++ 编写的,但是应用程序通过 JavaScript 运行。

这样一来,问题就解决了。一种语言就可以统治一切。而且,在整个应用程序中你只需要使用这一种语言。所以,我们需要深刻了解 node.js。这就是本文的主题。

下面这四个基本概念是你想要掌握 node.js 所必需的。我会尽可能长话短说向大家介绍它们。

1. 非阻塞或异步 I /O

由于 Node.js 是一种服务器端框架,所以它的一个主要工作就是处理浏览器请求。在传统的 I / O 系统中,当前请求只有当先前请求的响应(HTML 页面)已到达才会发出。这就是为什么它被称为阻塞 I /O。服务器阻塞其他请求是为了处理当前的请求,而这会导致浏览器的等待。

Node.js 不遵循 I / O 的这个原则。如果一个请求需要花费较长时间,那么 Node.js 会发送请求到事件循环(event loop)中,并继续在调用栈(call stack)中处理下一个请求。一旦未决请求完成处理,它就会告诉 Node.js,并将响应渲染在浏览器上。

用一个虚拟的例子来理解这一点:

阻塞 I / O

// take order for table 1 and wait...
var order1 = orderBlocking(['Coke', 'Iced Tea']);
// once order is ready, take order back to table.
serveOrder(order1);
// once order is delivered, move on to another table.
// take order for table 2 and wait...
var order2 = orderBlocking(['Coke', 'Water']);
// once order is ready, take order back to table.
serveOrder(order2);
// once order is delivered, move on to another table.
// take order for table 3 and wait...
var order3 = orderBlocking(['Iced Tea', 'Water']);
// once order is ready, take order back to table.
serveOrder(order3);
// once order is delivered, move on to another table.

在这个餐厅例子中,服务员给出菜单,等待订单完成,然后再回到餐桌根据菜单上菜。在当前客户点菜时,服务员就在旁边等待,不接受其他客户的菜单。

非阻塞 I / O

// take order for table 1 and move on...
orderNonBlocking(['Coke', 'Iced Tea'], function(drinks){return serveOrder(drinks);
});
// take order for table 2 and move on...
orderNonBlocking(['Beer', 'Whiskey'], function(drinks){return serveOrder(drinks);
});
// take order for table 3 and move on...
orderNonBlocking(['Hamburger', 'Pizza'], function(food){return serveOrder(food);
});

在这个例子中,服务员获得菜单,并告知厨师,然后返回取另一份菜单。在完成第一个菜单进程中,他既按照顺序给当前顾客上菜,也接受来自其他客户的点单。服务员不会因为阻塞来自于其他客户的点菜而浪费时间。

2. 原型

原型是 JavaScript 的一个复杂概念。不过因为在 Node.js 中你要多次用到原型,所以每个 JavaScript 开发人员都必须了解这个概念。

在实现经典继承的语言中,例如 Java,或 C ++,对于以代码重用为目的的语言,你首先必须写一个类,然后从该类创建对象或扩展该类。但是,在 JavaScript 中不存在类的概念。首先在 JavaScript 中创建一个对象,然后从这个对象中增加自己的对象,或创建新的对象。这就是所谓的原型传承和通过原型的实现。

每个 JavaScript 对象被链接到一个来自于它可以继承属性的原型对象。原型类似其他 OO 语言中的类,但不同的是,它们本身也是对象。每一个对象都链接到 Object.prototype,而 Object.prototype 自带 JavaScript 预定义。

如果你通过 obj.propName 或 obj[‘propName’] 查找属性,而对象并不具有可通过 obj.hasOwnProperty(‘propName’) 被检查的属性,那么 JavaScript 的运行时会在其原型对象中查找属性。如果原型对象也没有这样的属性,那么依次检查它的原型,直到找到匹配,或者到达 Object.prototype。如果该属性不存在原型链,那么它会导致一个未定义的值。

本次给大家推荐一个免费的学习圈,里面概括移动应用网站开发,css,html,webpack,vue node angular 以及面试资源等。 获取资料????????????
对 web 开发技术感兴趣的同学,欢迎加裙:????????????582735936 ????????????,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。
最后,祝大家早日学有所成,拿到满意 offer,快速升职加薪,走上人生巅峰。

通过下面的示例代码来理解这个概念:

if (typeof Object.create !== 'function') {Object.create = function (o) {var F = function () {};
        F.prototype = o;
        return new F();};
var otherPerson = Object.create(person);

当你创建一个新对象的时候,你必须选择一个应该是它的原型的对象。这里,我们添加了一个方法到 Object  function。该方法创建了一个使用另一个对象作为其原型的新对象,而原型作为参数传递给它。

当我们改变新对象的时候,它的原型不受影响。但是,当我们进行改变原型对象的时候,这些变化在所有基于该原型的对象上可见。

原型是一个复杂的概念。我将在另一篇文章中详细说明。

3. 模块

如果你曾经接触过 Java 中的包,那么 Node.js 中的模块也没有什么不同。如果没有,那么也不用担心。模块是包含特定目的代码的简单的 JavaScript 文件。模块模式用来使你的代码易于导航和使用。要使用模块属性,你需要在 JavaScript 文件中需求它,很像在 Java 类中导入包。

node.js 中有两种类型的模块。

核心模块 ——这些模块是用 Node.js 库预编译过的。核心模块的目的是提供开发者经常发生和重复的代码段,这些代码段如果不可用的话,会导致开发者陷入不得不一次又一次地写相同代码的处境。一些常见的核心模块是 HTTP,URL,EVENTS,FILE SYSTEM,等等。

用户定义模块 ——用户定义模块是开发人员在应用程序内创建用于特定目的的模块。当核心模块不能满足期望功能的时候就需要用户定义模块。

模块通过 require 函数提取。如果它是一个核心模块,那么参数仅仅是模块的名称。如果它是一个用户自定义模块,那么参数就是该模块在文件系统中的路径。例如:

// extract a core module like this
var http = require('http);
// extract a user defined module like this
var something = require('./folder1/folder2/folder3/something.js');

4. 回调函数

在 JavaScript 中,函数被认为是第一类对象。这意味着你可以对这些函数做所有可对常规对象做的操作。你可以赋值函数给变量,作为参数传递函数给方法,作为对象属性声明函数,甚至从函数返回函数。

回调函数是 JavaScript 中的匿名函数,它可以作为参数传递给其他函数,要么被执行或返回自函数稍后执行。这是回调函数——这个使用最广的函数编程范式的基础。

当我们将回调函数作为参数传递给另一个函数的时候,我们只能传递函数定义……换言之就是,我们不知道这个回调函数什么时候会执行。这完全取决于调用函数的机制。它会在以后的某个时间点“回调”,因此而得名。这也是非阻塞或 Node.js 异步行为的唯一基础,如下例所示。

setTimeout(function() {console.log("world");
}, 2000)
console.log("hello");

这是回调函数最简单的例子之一。我们将一个匿名函数作为一个参数传递,这个参数只需在控制台上记录一些输出到 setTimeout 函数。它是唯一的函数定义,但是不知道何时执行。这需要经过 2 秒后,通过第二个参数,调用 setTimeout 函数来决定。

首先,第二个日志语句记录输出到控制台,然后,2 秒钟后,回调函数中的日志语句记录输出。

// output
hello
world</pre>

上面这些就是 Node.js 新手必须知道的 4 个最重要的 JavaScript 概念。你的看法呢?希望大家能够畅所欲言!

本次给大家推荐一个免费的学习圈,里面概括移动应用网站开发,css,html,webpack,vue node angular 以及面试资源等。 获取资料????????????
对 web 开发技术感兴趣的同学,欢迎加裙:????????????582735936 ????????????,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。
最后,祝大家早日学有所成,拿到满意 offer,快速升职加薪,走上人生巅峰。

正文完
 0