大家都知道JavaScript的专长就是处理客户端也就是与浏览器打交道了,所有的与服务器端的交互必须交给后台语言处理程序去做,基于JavaScript不能与服务器进行直接交互这样一个现状,Ryan Dahl决定使用V8引擎来创建JavaScript服务器环境。在此简单叙述一下这样做的原因:

  • V8引擎很快
  • V8专注Web,所以在处理HTTP,DNS,TCP等方面特别擅长
  • 大多数Web开发人员都会JavaScript

用一句话来说就是Node.js是一个事件驱动的服务器端JavaScript环境。

也许有人会问了,什么是服务器端的JavaScript?

JavaScript与Web页面交互就是通常所称的客户端JavaScript,因为它发生在浏览器或者说客户端。服务器端JavaScript发生在把页面发送给浏览器之前的服务器上。

安装Node.js

(因为我的电脑win7,个人比较穷,也没有苹果电脑,后台开发能力也只能说略懂,也没有在Unix操作系统上测试过,所以在此申请一下,我的操作全部都是在微软平台上。不好意思啊)

nodejs官网首页 下载相应的版本安装即可,很简单的

验证Node.js是否安装正确

  1. 打开Node.js命令提示窗口
  2. 输入1+1
  3. 看一下是否界面显示2

第一个简单demo

1、创建server.js,代码如下

var http = require('http');

http.createServer(function (request, response) {//创建服务器
response.writeHead(200, { 'Content-Type': 'text/plain' });//回传到客户端的头信息
response.end('Hello World! ');//回传到客户端的信息
}).listen(3000,'127.0.0.1');//第一个参数为端口 第二个参数为主机地址 console.log('server running at http://127.0.0.1:3000');

2、开始--运行 cmd(也就是打开命令提示符窗口)  把当前路径cd转到server.js所在的目录

3、执行node server(本来是执行node server.js  但因为是js文件,所以默认可以省略.js)

4、打开浏览器,输入网址:http://127.0.0.1:3000  会发现浏览器显示hello world

在此备注一下:

  • 即使你只是修改js里面的哪怕一个字符,如果你想看到修改后的效果,那就必须得重新编译也就是说重新运行node命令
  • 要想停止服务器运行并返回终端,可以按ctrl+c(这个命令很方便的)
  • Node.js是运行的v8引擎上的,v8是同Google开发的开源的JavaScript引擎。事实上Node.js是个编程平台
  • 关于Node.js,并发的含义是一次做多件事件的能力

NPM(Node Package Manager)Node包管理器

npm允许开发人员在应用程序中创建、共享、重用模块。说句通俗一点的话,包就是一个功能模块,也确实是node.js的一个很有特色的地方,为开发人员提供了很多便利。

通过使用模块可以快速的给应用程序添加许多功能。模块通常可以为开发人员除去常见的困难。

模块就是可重用的代码库

模块相关demo

安装模块

npm install [module_name]

使用模块

var module=require('module');

demo具体步骤:

1、创建foo.js,代码如下

var _ = require('underscore');
_.each([1, 2, 3], function (num) {
console.log('underscore.js says ' + num);
});

2、打开命令提示符,将目录转到foo.js所在目录(文章下面的demo  这个步骤也是必须的 但我省略不写了哦)

3、运行npm install underscore  安装underscore包之后命令提示符中将显示相应的信息 并且在foo.js所在的目录下多一个node_modules文件夹,node_modules文件夹下有underscore包文件

4、运行node foo

如何找模块

在终端直接使用npm命令行工具来搜索 也就是npm search [模块的名称] 如果有多个关键字的话可用空格分开

提示:因为node.js允许大家只有有一个账户就可以上传包,也就是说任何人都可以是node.js模块的作者,所以尽管模块可通过npm获得,但并不代表它是得到良好测试或者说是稳定的,请使用模块的下载量和项目的问题数量作为模块的可靠性和成熟度的大致指南。

模块的安装方式

有两种方式

  1. 本地安装  npm install [module_name]
  2. 全局安装 npm install -g  [module_name]

全局安装意味着可以在文件系统的任何位置运行它。

本地安装模块意味着模块会被安装在项目内名为node_modules的文件夹中,而且它只可在该项目中使用。

全局安装模块意味着模块可在系统的任何一个地方使用。

作为 一条经验法则,请本地安装Node.js模块。

如何找模块文件

命令:npm docs [module_name]

这个命令执行之后会打开浏览器并进入模块作者所提供的文档页面,不信你可以在终端执行

npm docs underscore

通过运行如下命令查看项目的bug,这会打开浏览器并进入模块作者所提供的问题页面

npm bugs underscore

事实上还有一条查看源码命令(但是我电脑老是没法打开 提示说权限不够)

npm edit underscore

package.json

在C#中使用using来引用外部程序集,而在node.js中是使用package.json来指定依赖关系。npm允许开发人员使用package.json文件来指定在应用程序中要用的模块,并且通过单个命令来安装它们:npm install

可想而知这样的方式有哪些好处:

  • 无需一个一个地安装模块
  • 其实开发人员可以很容易的安装你的应用程序
  • 应用程序的依赖关系存储在一个单一的地方

package.json相关demo

1、建立一个foo.js文件,代码如下所示:

var _ = require('underscore');
_.each([1, 2, 3], function (num) {
console.log('underscore.js says ' + num);
});

2、在foo.js同目录下建立一个package.json的文件,代码如下所示

{
"name":"example02",
"version":"0.0.1",
"dependencies":{
"underscore":"~1.2.1"
}
}

3、在终端执行npm install 这时候将会看到underscore库安装在node_modules文件夹下

建议:即使应用只需要安装一个模块,还是强烈建议使用package.json文件来管理Node.js模块

未完待续(考虑到篇幅太长的问题  后续文章将继续探讨)

Node实践之一的更多相关文章

  1. Node实践之二

    先从一个简单的demo说起,用cmd打开命令提示符,输入echo Hello,大家是不是看到终端上显示出了Hello字样,事实上这就是一个简单的事件. 回到正题,相信提到node.js,免不了让人想起 ...

  2. 一个月时间整理《深入浅出Node.js》

    今天终于把朴灵老师写的<深入浅出Node.js>给学习完了, 这本书不是一本简单的Node入门书籍,它没有停留在Node介绍或者框架.库的使用层面上,而是从不同的视角来揭示Node自己内在 ...

  3. 深入浅出Nodejs读书笔记(转)

    Node简介 这一章简要介绍了Node,从中可以了解Node的发展历程及其带来的影响和价值. 为什么叫Node?起初,Ryan Dahl称他的项目为web.js,就是一个Web服务器,但是项目的发展超 ...

  4. 五年 Web 开发者 star 的 github 整理说明

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:樊东东 前端从业几年,积累了不少github开源库. 有时候想查阅以前star的库,但不好找,github大多库都是英文说明,对中文 ...

  5. nodejs图片总结

    今天终于把朴灵老师写的<深入浅出Node.js>给学习完了, 这本书不是一本简单的Node入门书籍,它没有停留在Node介绍或者框架.库的使用层面上,而是从不同的视角来揭示Node自己内在 ...

  6. 深入浅出Nodejs读书笔记

    深入浅出Nodejs读书笔记 转:http://tw93.github.io/2015-03-01/shen-ru-qian-chu-nodejs-reading-mind-map.html cate ...

  7. babeljs源码

    babel.min.js!function(e,t){"object"==typeof exports&&"object"==typeof mo ...

  8. 基于 Angularjs&Node.js 云编辑器架构设计及开发实践

    基于 Angularjs&Node.js 云编辑器架构设计及开发实践 一.产品背景 二.总体架构 1. 前端架构 a.前端层次 b.核心基础模块设计 c.业务模块设计 2. Node.js端设 ...

  9. [转] Node.js 服务端实践之 GraphQL 初探

    https://medium.com/the-graphqlhub/your-first-graphql-server-3c766ab4f0a2#.n88wyan4e 0.问题来了 DT 时代,各种业 ...

随机推荐

  1. Oracle创建表空间、创建用户以及授权

    Oracle安装完后,其中有一个缺省的数据库,除了这个缺省的数据库外,我们还可以创建自己的数据库. 为了避免麻烦,可以用’Database Configuration Assistant’向导来创建数 ...

  2. MySQL 复制表

    MySQL 复制表 如果我们需要完全的复制MySQL的数据表,包括表的结构,索引,默认值等. 如果仅仅使用CREATE TABLE ... SELECT 命令,是无法实现的. 本文将为大家介绍如何完整 ...

  3. 基于注解的SpringMVC

    相比传统的继承Controller体系中某些类的方式,SpringMVC的注解具有以下优点: 1.Controller不再需要继承某个特定类,只是简单的POJO. 2.请求映射的配置非常方便灵活. 3 ...

  4. 曲演杂坛--当ROW_NUMBER遇到TOP

    值班期间研发同事打来电话,说应用有超时,上服务器上检查发现有SQL大批量地执行,该SQL消耗IO资源较多,导致服务器存在IO瓶颈,细看SQL,发现自己都被整蒙了,不知道这SQL是要干啥,处理完问题赶紧 ...

  5. PostgreSQL-角色、库、模式、表

    由于不了解postgresql的psql工具,安装完数据库后就直接用pgadmin或navicat来连接操作,在确认初始化后的库中默认有些什么东西后竟然一直无处下手,在还没有了解pg大致体系的情况下搞 ...

  6. 基于Zabbix IPMI监控服务器硬件状况

    基于Zabbix IPMI监控服务器硬件状况 zabbix ipmi 公司有多个分部,且机房没有专业值班,机房等级不够.在这种情况下,又想实时监控机房环境,于是使用IPMI方式来达到目的.由于之前已经 ...

  7. 【Bootstrap Demo】入门例子创建

    本文简单介绍下如何来使用 Bootstrap,通过引入 Bootstrap,来实现一个最基本的入门例子. 在前一篇博文[Bootstrap]1.初识Bootstrap 基础之上,我们完全可以更加方便快 ...

  8. CodeForces 485C Bits[贪心 二进制]

    C. Bits time limit per test1 second memory limit per test256 megabytes inputstandard input outputsta ...

  9. Vijos1404遭遇战[最短路建模]

    背景 你知道吗,SQ Class的人都很喜欢打CS.(不知道CS是什么的人不用参加这次比赛). 描述 今天,他们在打一张叫DUSTII的地图,万恶的恐怖分子要炸掉藏在A区的SQC论坛服务器!我们SQC ...

  10. GNU make使用变量⑤变量的引用、定义等

    在 Makefile 中,变量是一个名字(像是 C 语言中的宏),代表一个文本字符串(变量的值).在 Makefile 的目标.依赖.命令中引用变量的地方,变量会被它的值所取代(与 C 语言中宏引用的 ...