关于npm,gulp,webpack

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、图片等都作为模块来使用和处理。

优势:

  1. 兼容common.js、AMD、ES6语法
  2. js文件、css文件、图片、html文件都可以打包
  3. 有很多插件可使用
  4. 有独立的配置文件webpack.config.js
  5. 可以将代码切割成不同的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'))
})

实战

企业站
代码

你可能感兴趣的:(关于npm,gulp,webpack)