学会node.js(一)

如何安装?

点这里 + 下一步

学会node.js(一)_第1张图片
timer.png

现在让我们开始第一个node程序吧,打开vim或者sublime:

学会node.js(一)_第2张图片
5551.png

将文件保存为moyu.js,打开命令行,进入moyu.js的文件夹,执行:

node moyu.js

如果一切正常,你会在命令行下面看到moyupeixun
console是node.js提供的控制台对象,其中包含了向标准输出写入的操作,跟浏览器的console功能类似,node是可执行程序,可以解释执行后面的脚本。

Npm使用介绍

npm是随同nodejs一起安装的包管理工具,能解决nodejs代码部署上的很多问题,常见的应用场景如下:

  • 允许用户从npm服务器下载别人编写的第三方包到本地使用
  • 允许用户从npm服务器下载并安装别人编写的命令行程序到本地使用
  • 允许用户将自己编写的包或命令行程序上传到npm服务器供别人使用,如这个

由于新版的nodejs已经集成了npm,所以之前npm也一并安装好了,同样可以输入npm -v测试是否安装成功:
如果你使用的是旧版本的npm,可以通过这条命令升级:

npm install npm -g 

使用npm命令安装模块
npm安装node.js模块语法格式如下:

npm install 

比如:

npm install myQuery

安装好之后,myQuery就放在了工程目录 的node_modules目录中了,因此,我们要想使用直接require("myQuery")就好了,无需使用第三方包路径。

全局安装和本地安装

全局安装
npm的包安装分为本地安装(local)、全局安装(global)两种,从敲的命令来看,差别只是有没有-g之分:

本地安装
1、将安装包放在./node_modules下,如果没有node_modules目录,会在当前执行npm命令的目录下生成node_modules目录
2、可以通过require("myQuery")来引入本地安装的包

npm install myQuery

全局安装

$ npm install myQuery  -g 

使用package.json
package.json位于模块的目录下,用于定义包的属性,接下来我们来看一下yQuery包的package.json文件:

{

"name": "myquery",

"version": "1.0.4",

"description": "myquery is a JavaScript library for study or use in the little project,if you are dev the big project,please use the jQuery",

"main": ["dist/myquery.js"](https://github.com/moyu-edu/myQuery/blob/master/dist/myquery.js),

"directories": {

"doc": ["doc"](https://github.com/moyu-edu/myQuery/blob/master/doc),

"example": ["examples"](https://github.com/moyu-edu/myQuery/blob/master/examples)

},

"homepage": "http://moyu-edu.github.io/myQuery/",

"repository": {

"type": "git",

"url": "https://github.com/moyu-edu/myQuery.git"

},

"scripts": {

"test": "echo \"Error: no test specified\" && exit 1"

},

"keywords": [

"javascript",

"library",

"dom",

"ajax",

"form"

],

"author": "ericzheng",

"license": "GPL-3.0",

"devDependencies": {

"gulp-autoprefixer": "^3.1.0",

"gulp-eslint": "^1.1.1",

"gulp-font-spider": "^0.2.0",

"gulp-jslint": "^0.2.2",

"gulp-less": "^3.0.5",

"gulp-live-server": "0.0.29",

"gulp-notify": "^2.2.0",

"gulp-rename": "^1.2.2",

"gulp-scss": "^1.3.15",

"gulp-sourcemaps": "^1.6.0",

"gulp-uglify": "^1.5.1",

"gulp-util": "^3.0.7",

"gulp-watch": "^4.3.5",

"map-stream": "0.0.6",

"qunitjs": "^1.20.0"

},

"dependencies": {

"express": "^4.13.3"

}

}

说明:

  • name 包名
  • version 包的版本号
  • description 包的描述
  • homepage 包的官网
  • author:作者
  • contributors 包的其他贡献者
  • dependencies 依赖包列表,如果依赖包没安装,npm install的时候,会自动将依赖包安装在node_modules下面
    形式有如下几种:
version 严格匹配某个版本
>version 必须大于某个版本
>=version
=version1 <=version2
range1 || range2 满足range1 或range2
git://... git地址
user/repo 同上
tag 指定某个tag的版本
path/path 本地包所有文件夹
  • repository 包代码存放在地方的类型,可以是git,svg之类的,git可以在github上
  • main main字段是一个模块id,它是一个指向你程序的主要项目部,就是说,如果你require("myQuery"),那么会引用main这里指定的js
  • keywords 关键字
  • man 帮助文件
  • directories commonjs要求的目录结构
  • scripts 可以通过这个来自动化脚本
  • config 添加一些设置,供scripts来读取

卸载模块

我们可以使用以下命令来卸载node.js模块

npm uninstall myQuery

卸载后,你可以到node_modules目录下来查看包是否还存在,或者使用以下命令

npm ls

更新模块

我们可以使用以下命令更新模块

npm update myQuery

搜索模块

npm search myQuery

创建模块

创建模块,package.json文件是必不可少的,我们可以使用npm生成package.json文件,生成的文件包含了基本的结果:

npm init
学会node.js(一)_第3张图片
31111.png

如果你想把你创建的模块发布到npmjs.com,可以这样做:

npm adduser
npm publish

需要注意的是,你publish了一次再重复提交会报错的,你只能改一下你的版本号

npm 常用命令

  • npm instal 安装包
  • npm publish 发布包
  • npm help
  • npm update
  • npm cache clear清空npm缓存
  • npm unpublish 可以撤销发丰的某个版本代号

你可能感兴趣的:(学会node.js(一))