资讯专栏INFORMATION COLUMN

几分钟的阅读让你明白node.JS的强大 走上web后端开发的道路 (一版)

libxd / 3075人阅读

摘要:这些特性不仅带来了大的性能提升,还减少多线程程序设计的复杂性,进而提高了开发效率。由公司建立的云计算平台率先支持了。

前言

本文章主要写给那些想了解node语言的开发,我的目标希望大家通过阅读本篇文章能够简单使用node进行开发,以及了解一些事件驱动的异步编程风格,主要分node的背景,安装配置,模块创建引用等几个方面描述

建议大家在阅读本篇文章途中 可以亲自尝试一下我所带来的小例子,这样才能更好的掌握!

背景

Node.js,或者Node,是一个可以让JavaScript 运行在服务器端的平台。它可以让JavaScript 脱离浏览器的束缚运行在一般的服务器环境下,就像运行Python、Perl、PHP、Ruby程序一样。你可以用Node.js 轻松地进行服务器端应用开发,Python、Perl、PHP、Ruby 能做的事情Node.js 几乎都能做,而可以做得更好。

Node.js 是一个为实时Web (Real-timeWeb) 应用开发而诞生的平台,它从诞生之初就充分考虑在实时响应超大规模数据要球下架构的可扩展性。这使得它摒弃了传统平台依靠多线程来实现高并发的设计思路,而采用了线程异式I/O事件驱动式的程序设计模型。这些特性不仅带来了大的性能提升,还减少多线程程序设计的复杂性,进而提高了开发效率。Node.js 最初是由Ryan Dahl 发起的开源项目,后来被Joyent 公司注意到。Joyent 公司将Ryan Dahl 招人旗下,因此现在的Node.js 由Joyent 公司管理并维护。尽管它诞生的时间( 2009年) 还不长,但它的周围配经形成了一个庞大的生态系统。Nodejs 有着强大而灵活的包管理器(nodepackagemanager,npm),目前已经有上万个第三方模块,其中有网站开发框架,有MySQL、PostgreSQL、MongoDB 数据库接口,有模板语言解析、CSS 生成T 具邮件、加密、图形、调试支持,甚至还有图形用户界面和操作系统API 具。由VMware 公司建立的云计算平台CloudFoundry 率先支持了Node.js。2011年6月,微软宣布与Joyent 公司合作,将Node.js 移植到Windows,同时Windows Azure 云计算平台也支持Node.js。Node.js 目前还处在迅速发展阶段,相信在不久的未来它一定会成为流行的Web应用开发平台。

让我们从现在开始,一同探索Node.js 的美妙世界吧!

安装配置

window上面很容易安装node 只需要访问node官网,点击DownLoad链接,然后选择window Installer,下载安装包,下载完成后打开 点击Next 如图,就可以安装完成

为了检测安装是否完成,打开命令行CMD,然后输入node 如果下载成功 便进入node交互模式 如图:

通过这种方式安装还会自带NPM 我们可以直接在使用它!

Mac OS X上安装Node.js
只需要访问node官网,点击DownLoad链接,然后选择Macintosh Installer,下载安装包,下载完成后运行安装包,根据提示完成安装:

node和npm都会安装到/usr/local/bin目录下,安装过程需要管理员权限,安装完后在终端输入node回车进入node交互模式,如果提示-bash:node :command not found 那就是没有已正确的方式安装完成。需要重新安装

安装完成之后 练习一下

进入node交互环境

consoloe.log("hello,node.js")
输出 // hello,node.js

1 + 2
输出 // 3

可以进行加减乘除 运算

接下来创建一下第一个应用 也可以叫模块 !
打开你所常用的文本编辑器输入

 var http = require("http");  //通过require对象(指令)来引用http模块
                   //参数request代表是发送请求对象    response代表是响应请求的对象
 http.createServer(function(req,res){ //通过http对象的方法createServer创建一个服务器
    res.writeHead(200, {"Content-Type": "text/html"}); //规定数据的content-type文本类型为text/html
    res.write("

Node.js

"); //响应请求然后write 字体大小为h1标准的node.js字样 res.end("

Hello World

"); //发送响应数据为 hello world; }).listen(8888); //该服务监听本地host 端口8888 console.log("Server running at http://127.0.0.1:8888/"); //在终端告诉用户该服务运行与8888端口

保存为hello.js

然后你打开当前目录,打开命令行输入 node hello.js 你就会在命令行处看到Server running at http://127.0.0.1:8888/ ,然后就可以打开浏览器输入这个http://127.0.0.1:8888/ 就可以看到刚才写的响应数据

**是不是特别简单!!!!!

模块的创建与引用

学习node.JS必须懂的一些地方

什么是模块?

如何创建并加载模块?

如何创建一个包?

如何使用包管理?

这次先讲前俩点,和稍微渗透3 4 点

第一点!
模块是Node.js应用程序的基本组成部分,文件和模块是一一对应的。换句话说,一个Node.js文件就是一个模块,这个文件可能是JavaScript代码,JSON或者编译过的C/C++扩展。

var http= require("http"),其中http是Node.js的一个核心模块,其内部是用C++实现的,外部用Javascript封装。我们通过require函数获取这个模块 ,从而才能使用其中的对象。

第二点!
在Node.js,创建一个模块非常简单,因为一个文件就是一个模块,我们要关注的问题仅仅只是如何在其他文件获取这个模块,Node.js提供了exports和require俩个对象,其中exports是模块公开的接口,require用于从外部获取一个模块的接口,即获取模块的exports对象。

// 创建模块
//module.js

var name;
exports.setName = function(thyName){
    name = thyName;
}

exports.sayHello = function() {
    console.log("hello" + name)
}

同级目录下创建getmodule.js

//引入模块
// getmodule.js

var myModule = require("./module");
myModule.setName("zhangsan");
myModule.sayHello();

在命令行运行node getmodule.js   输出// hello zhangsan

以上该例子中,module.js通过exports对象吧setName 和 sayHello作为模块的访问接口,在getmodule.js中通过
require("./module")加载这个模块,然后就可以之间访问module.js中exports对象的成员函数了

require 不会重复加载模块,无论调用多少次require,获得的模块都是同一个,修改一下上面的getmodule.js

//修改getmodule.js 
var hello1 = require("./module");
hello1.setName("zhangsan");

var hello2 = require("./module");
hello2.setName("zhangsan2");

hello1.sayHello(); // 输出结果为zhangsan2!

因为变量hello1和变量hello2执行都是同一个实例,因此hello1.setName的结果被hello2.setName覆盖!结果由后者决定

把一个对象封装到模块中 例如:

//hello.js

function hello (){
  var name;
  
  this.setName = function(thyName) {
    name = thyName;
  }
  
  this.sayHello = function() {
     console.log("hello" + name);
  }

 };

module.exports = Hello; //导出该模块接口; 如果按导出方法哪有 exports.Hello = Hello 引入require("./hello").Hello;

 按上面module.exports = Hello导出 引入模块;
 

 //getHello.js

 var Hello = require("./hello");
 hello = new Hello();
 hello.setName("zhangsan");
 hello.sayHello(); //输出hello zhangsan

第三点 /创建包

 包是在模块基础上更深一步的抽象,Node.js的包类型与C/C++的函数库或者Java/.Net的类库.将某个独立的功能封装起来,用于发布

更新,依赖管理和版本控制.Node.js根据CommonJS规范实现了包机制,开发了npm来解决包发布和获取;

 node.js的包就是一个目录,包含一个JSON格式的包说明文件package.json.   package.json必须在包的顶层目录下,其他遵循CommonJS的规范不是特别严格

第四点 /包管理

node.js包管理,即npm是Node.js官方提供的包管理工具,它已经成为了Node.js包的标准发布平台,npm提供了命令行工具,你可以很方便去下载 安装 升级 删除包! 也可以发布 维护你自己的包!

   npm install(i) pagejson_name //下载的格式 本地模式  末尾加-g (--global) 就是全局模式
   
   npm uninstall  pagejson_name //删除的格式  末尾加-g (--global) 就是全局模式
   
   //等等很多命令 可以去搜索 就不一一列举了
   
   
   
   

待续!!

本来应该把node一些核心模块一块说了的 比如全局对象 process console 事件驱动events 事件发射器 error事件 继承EventEmitter 等等
但是今天确实身体不适,还请谅解,可能会休息几天 所以提前把这版发出来,暂时把他定位为第一版 对于node的探索,我还会更新 第二版的,下一章节除了会补全这次没有讲到了还会带大家利用node来进行web开发!初步定稿为1月2号!

http 与express 安装与搭建

路由的控制 如工作原理 创建路由规则等等

模板引擎 什么是?怎么使用?如何利用布局?等等

结语

希望大家可以通过看这篇文章能有收获,最简单的证明就是把项目用到node的配置文件再去拿出来看看,最起码知道它是怎么个流程,不一定知道它干什么,但是知道它从哪来 是导出还说引用!这就是进步!

//进一步学习参考这篇书 学习
https://www.nodebeginner.org/

不要做幻想的乞丐,要做幸福的创造者!!!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/90444.html

相关文章

  • JavaScript精编干货

    摘要:老姚浅谈怎么学鉴于时不时,有同学私信问我老姚,下同怎么学前端的问题。撸码听歌,全局控制。 浅析用 js 解析 xml 的方法 由于项目上需要解析 xml,于是各种百度,然后自己总结了下各个主流浏览器解析 xml 的方法,只能是很浅显的知道他的用法,但是还没有深层次的研究。 装 X - 建立自己的斗图网站库 之前加过一个斗图群,看到很多经典的表情,然后就收藏到了 QQ, 迫于本屌丝开不起...

    Fourierr 评论0 收藏0
  • 前端基础

    摘要:谈起闭包,它可是两个核心技术之一异步基于打造前端持续集成开发环境本文将以一个标准的项目为例,完全抛弃传统的前端项目开发部署方式,基于容器技术打造一个精简的前端持续集成的开发环境。 这一次,彻底弄懂 JavaScript 执行机制 本文的目的就是要保证你彻底弄懂javascript的执行机制,如果读完本文还不懂,可以揍我。 不论你是javascript新手还是老鸟,不论是面试求职,还是日...

    graf 评论0 收藏0
  • CNCF案例研究:Nav

    摘要:在评估了许多业务流程解决方案后,该公司决定采用在上运行的。我们必须不停运行,我们必须保持可用,我们必须有最少的停机时间。该公司将其群集隔离到一个不受限制的区域和一个限制区域,该区域有自己的一组节点,用于数据保护。 一家初创公司如何通过Kubernetes将其基础设施成本降低50% showImg(https://segmentfault.com/img/bVbqosb?w=1024&h...

    waruqi 评论0 收藏0
  • CNCF案例研究:Nav

    摘要:在评估了许多业务流程解决方案后,该公司决定采用在上运行的。我们必须不停运行,我们必须保持可用,我们必须有最少的停机时间。该公司将其群集隔离到一个不受限制的区域和一个限制区域,该区域有自己的一组节点,用于数据保护。 一家初创公司如何通过Kubernetes将其基础设施成本降低50% showImg(https://segmentfault.com/img/bVbqosb?w=1024&h...

    Cheriselalala 评论0 收藏0
  • 2016-JavaScript之星

    摘要:在,是当之无愧的王者,赢得了与之间的战争,攻陷了的城池。于月发布了版本,这一版本为了更好的表现加入了渲染方式。前端框架这个前端框架清单可能是年疲劳的元凶之一。的创建者,目前在工作为寻找构建简单性和自主配置性之间的平衡做了很大的贡献。 春节后的第一篇就从这个开始吧~本文已在前端早读课公众号上首发 原文链接 JavasScript社区在创新的道路上开足了马力,曾经流行过的也许一个月之后就过...

    Binguner 评论0 收藏0

发表评论

0条评论

libxd

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<