npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

msg-echo

v1.0.3

Published

JS是脚本语言,脚本语言都需要一个解析器才能运行。对于写在HTML页面里的JS,浏览器充当了解析器的角色。而对于需要独立运行的JS,NodeJS就是一个解析器。

Downloads

10

Readme

nodejs

什么是nodejs

JS是脚本语言,脚本语言都需要一个解析器才能运行。对于写在HTML页面里的JS,浏览器充当了解析器的角色。而对于需要独立运行的JS,NodeJS就是一个解析器。

运行在NodeJS中的JS的用途是操作磁盘文件或搭建HTTP服务器,NodeJS就相应提供了fs、http等内置对象。

安装node

1.mac:

建议使用brew安装。brew 全称Homebrew 是Mac OSX上的软件包管理工具Homebrew 安装和卸载工具 只用一行命令就能完成 因为mac 自带ruby ,所以只需要执行

ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)"  

安装完可以通过brew -v 检查是否安装成功。

然后安装node,只需执行brew install node即可。

2.windows:

可以去官网https://nodejs.org选择和系统版本匹配的.msi后缀的安装文件

如何运行

1.直接运行js代码: 首先输入node进入命令交互模式,然后就可以像浏览器里头的控制台一样输入js代码,例如:

$ node
> console.log('Hello World!');
Hello World!

若想退出交互模式,则两次control+c活着输入.exit

2.运行文件: 例如执行在test目录下的hello.js

node ./test/hello.js

模块机制

在NodeJS中,一般将代码合理拆分到不同的JS文件中,每一个文件就是一个模块,而文件路径就是模块名。

在编写每个模块时,都有require、exports、module三个预先定义好的变量可供使用。

1.require

require就是用来加载模块的一个函数,可以通过传入模块名来加载模块,因为文件路径就是模块名,所以可以穿入相对路径或者绝对路径来加载模块。另外,以.js为扩展名的可以省略扩展名。

另外可以用require引入json文件,例如本项目中的 ./test/hellojson.js中:

var helloData=require('./json/hello.json');
function hello() {
    console.log(helloData.helloCont);
}
hello();

可以引入到./test/json/hello.json,并获取里头的数据。

2.exports

exports对象是当前模块的导出对象,用于导出模块公有方法和属性。别的模块通过require函数使用当前模块时得到的就是当前模块的exports对象。例如本项目中./test/helloExport.js:

exports.hello=function(){
    console.log("Hello node!")
}

对外提供一个对象,对象里头有hello方法,然后通过./test/exportTest.js调用:

var helloExport=require('./helloExport');
helloExport.hello()

3.module 通过module对象可以访问到当前模块的一些相关信息,但最多的用途是替换当前模块的导出对象。例如模块导出对象默认是一个普通对象,如果想改成一个函数的话,可以使用以下方式:

例如./test/helloModule.js:

module.exports=function(){
    console.log("Hello node!")
}

然后通过./test/moduleTest.js调用:

var hello=require('./helloModule');
hello()

这里不像exports默认导出对象那样,需要通过找到对象的属性去调用,这里直接导出的是一个方法。

注意:一个模块中的JS代码仅在模块第一次被使用时执行一次,并在执行过程中初始化模块的导出对象。之后,缓存起来的导出对象被重复利用。

模块路径解析规则

前面介绍的可以通过相对路径与绝对路径两种路径找到模块,但是这两种方法在模块之间建立了强耦合关系,一旦某个模块文件的存放位置需要变更,使用该模块的其它模块的代码也需要跟着调整,变得牵一发动全身。

因此,require函数支持第三种形式的路径,并依次按照以下规则解析路径,直到找到模块位置。

1.内置模块

如果传递给require函数的是NodeJS内置模块名称,不做路径解析,直接返回内部模块的导出对象,例如require('fs')

2.node_modules目录

NodeJS定义了一个特殊的node_modules目录用于存放模块。例如如果在绝对路径/home/test/hello.js中以require('foo/bar')方式加载模块,则NodeJS依次尝试使用以下路径去寻找模块:

/home/test/node_modules/foo/bar
 /home/node_modules/foo/bar
 /node_modules/foo/bar

3.NODE_PATH环境变量

NodeJS允许通过NODE_PATH环境变量来指定额外的模块搜索路径。NODE_PATH环境变量中包含一到多个目录路径,路径之间在Linux下使用:分隔,在Windows下使用;分隔。

例如定义了以下NODE_PATH环境变量:

NODE_PATH=/home/user/lib:/home/lib

当使用require('foo/bar')的方式加载模块时,则NodeJS依次尝试以下路径。

 /home/user/lib/foo/bar
 /home/lib/foo/bar

包(package)

由多个子模块组成的大模块称做包,并把所有子模块放在同一个目录里。 在所有的子模块中有一个入口模块,这个入口子模块将包里的其他子模块都串联起来,并且向外导出一个对象,这个对象也是这个包的导出对象。

使用这个包时只需要引入这个包的入口模块,一半入口模块都命名为index.js,因为引用该包的时候,路径只需到包的位置,而不用到入口模块的位置。例如目录结构如下:

├── hello
│   ├── index.js
│   └── modules
│       ├── actions.js
│       ├── object.js
│       └── subject.js
└── test.js

其中hello是一个包,里头包括index.js,actions.js,object.js,subject.js四个模块,其中index.js为入口模块。test.js为测试该包,如下:

var hello=require('./hello');
hello();

这样做的好处就是感觉上整个hello目录被当作单个模块使用,更有整体感。

如果想自定义入口模块的文件名和存放位置,就需要在包目录下包含一个package.json文件,并在其中指定入口模块的路径。如下:

├── animal
│   ├── main.js
│   ├── modules
│   │   ├── actions.js
│   │   ├── object.js
│   │   └── subject.js
│   └── package.json
└── test.js

animal包里头并没有index.js,因此如果使用该包还是用原来方式require("./animal")会报错,这时需要加一个package.json,在这里头指定入口模块,package.json如下:

{
    "name":"animal",
    "main":"./main.js"
}

命令行程序

使用NodeJS编写的东西,要么是一个包,要么是一个命令行程序,而前者最终也会用于开发后者(即开发者在自己的代码里头引用包然后使用包)。后者命令行程序则是在系统控制台中通过命令使用。

例如我们还是接着上面的animal例子。在commandLineTest目录如下:

├── main.js
├── modules
│   ├── actions.js
│   ├── object.js
│   └── subject.js
└── package.json

其中main.js为包入口模块,所以在系统控制台使用的话,应该在该目录下运行脚本:

node main.js

而如果想在任何目录下运行的话则应该:

node [main.js的全路径]

这种使用方式看起来不怎么像是一个命令行程序,下边的才是我们期望的方式,直接输入命令如下:

animal

这时有两种方法实现:

1)第一种是将 main.js 的路径加入环境变量 PATH

i. 针对类unix系统:

sudo ln -s [main.js全路径] /usr/local/bin/animal

ii. 在Windows系统下的做法完全不同,我们得靠.cmd文件来解决问题。假设node-echo.js存放在C:\Users\user\bin目录,并且该目录已经添加到PATH环境变量里了。接下来需要在该目录下新建一个名为node-echo.cmd的文件,文件内容如下:

@node "C:\User\user\bin\node-echo.js" %* 这样处理后,我们就可以在任何目录下使用node-echo命令了。

2)第二种是在当前目录下新建 package.json ,加上bin属性:


{
    "name": "animal",
    "main": "./main.js",
    "bin": {
        "animal": "./main.js"
    }
}

然后在当前目录执行npm link

这样就可以在任何目录下执行animal就运行animal模块了

注意:若提示文件是可以执行但是不能运行且格式问题,如下:

Failed to execute process '/usr/local/bin/animal'. Reason:
exec: Exec format error
The file '/usr/local/bin/animal' is marked as an executable but could not be run by the operating system.

则是因为执行文件开头并没有指定解析器,应该在执行文件开头指定node为解析器(#!/usr/bin/env node),如此例子中main.js:

#!/usr/bin/env node
var subject=require('./modules/subject');
var actions=require('./modules/actions');
var object=require('./modules/object');
console.log(subject("Cat ")+actions("eat ")+object("mouse"))

示例项目结构

注意:如果发布了一个包,要想更新,则应该升版本。然后如果本地是使用命令行的话,再用的时候则应该npm install [module] -g更新全局变量,如果只是其他包依赖此包,则npm update即可。