1. 如何全局安装一个 node 应用?
npm install -global xxx
2. package.json 有什么作用?
package.json
是通过npm init
初始化生成出来的,来描述这个包的信息。
{
"name": "angular-tour-of-heroes", // 包名字
"version": "0.0.0", // 版本
"license": "MIT", // 版权信息
"scripts": { // 脚本命令,前面为命令,后面为命令所执行的内容
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true, // 拒绝发到npm上
"dependencies": { // 项目运行依赖(项目运行所需要的模块)
"@angular/animations": "^4.2.4",
"@angular/common": "^4.2.4",
"@angular/compiler": "^4.2.4",
"@angular/core": "^4.2.4",
"@angular/forms": "^4.2.4",
"@angular/http": "^4.2.4",
"@angular/platform-browser": "^4.2.4",
"@angular/platform-browser-dynamic": "^4.2.4",
"@angular/router": "^4.2.4",
"core-js": "^2.4.1",
"rxjs": "^5.4.2",
"zone.js": "^0.8.14"
},
"devDependencies": { // 项目开发依赖(项目开发中所需要的模块)
"@angular/cli": "1.3.0",
"@angular/compiler-cli": "^4.2.4",
"@angular/language-service": "^4.2.4",
"@types/jasmine": "~2.5.53",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "~3.1.1",
"jasmine-core": "~2.6.2",
"jasmine-spec-reporter": "~4.1.0",
"karma": "~1.7.0",
"karma-chrome-launcher": "~2.1.1",
"karma-cli": "~1.0.1",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.1.2",
"ts-node": "~3.2.0",
"tslint": "~5.3.2",
"typescript": "~2.3.3"
}
}
3.npm install --save app 与 npm install --save-dev app有什么区别?
-
npm install --save app
表示产品运行时所需要的依赖,并添加到dependencies,没有这些依赖项目就无法运行。 -
npm install --save-dev app
表示开发时所需要的依赖,并添加到devDependencies,当产品上线时可以忽略这些依赖。
4. node_modules的查找路径是怎样的?
当require一个模块xxx时,会首先在当前目录下寻找node_modules下的xxx,若没有,则返回到上一级目录的node_modules下寻找xxx,最终会找到根目录下node_modules下的xxx。
5.webpack是什么?和其他同类型工具比有什么优势?
webpack 是一款模块加载器兼打包工具,它能把各种资源 JS、CSS、图片等都作为模块来使用和处理。
优势:
- 兼容common.js、AMD、ES6语法
- js文件、css文件、图片、html文件都可以打包
- 有很多插件可使用
- 有独立的配置文件webpack.config.js
- 可以将代码切割成不同的chunk,实现按需加载,降低了初始化时间;
6.npm script是什么?如何使用?
类似于一个脚本命令。
"scripts": { // 脚本命令,前面为命令,后面为命令所执行的内容
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
当在控制台输入前面的指令时,便会脚执行脚本指令所包含的内容。
7.gulp是什么?使用 gulp 实现图片压缩、CSS 压缩合并、JS 压缩合并。
gulp是一款可以实现自动化的工具,能帮助你在开发过程中自动完成任务。
'use strict'
var gulp = require('gulp');
// 图片压缩
// npm install --save gulp-imagemin
var imagemin = require('gulp-imagemin');
gulp.task('img',function(){
gulp.src('src/images/*')
.pipe(imagemin())
.pipe(gulp.dest('dist/images'))
})
// css压缩合并
// npm install --save gulp-minify-css 压缩CSS
// npm install --save gulp-rename css文件更名
// npm install --save gulp-concat 文件合并
var concat = require('gulp-concat');
var minifycss = require('gulp-minify-css');
var rename = require('gulp-rename');
gulp.task('cssMin',function(){
gulp.src('src/css/*.css')
.pipe(concat('merge.css'))
.pipe(rename({suffix:'.min'}))
.pipe(minifycss())
.pipe(gulp.dest('dist/css'))
})
// js压缩合并
// npm install --save gulp-uglify
// npm install --save gulp-concat
// npm install --save gulp-rename
var concat = require('gulp-concat');
var rename = require('gulp-rename');
var uglify = require('gulp-uglify');
gulp.task('jsMin',function(){
gulp.src('src/js/*.js')
.pipe(concat('merge.js'))
.pipe(rename({suffix:'.min'}))
.pipe(uglify())
.pipe(gulp.dest('dist/js'))
})