美文网首页
webpack基础知识

webpack基础知识

作者: 七_五 | 来源:发表于2017-06-27 00:11 被阅读0次

    1: 如何全局安装一个 node 应用?

    npm install -g xxx
    npm===>node package manager

    题目2: package.json 有什么作用?

    配合npm使用,用来定义模块包,主要包括以下几点:

    • 定义模块包的依赖管理[devDependencies/dependencies]、
    • 定义包的基本描述信息[description、name、version等]
    • 定义包的使用方式[npm scripts]
    • 定义包的主程序入口模块标示[main]
    • 定义包的可执行文件地址[bin]
    • 定义包的bug、people、issue、license等其他信息

    题目3: npm install --save app 与 npm install --save-dev app有什么区别?

    相同点:都会在项目的node_modules目录下安装app

    • --save 将产品运行时(或生产环境)需要的依赖模块添加到 package.json 的 dependencies 中,在发布后还需要继续使用,否则就运行不了。
    • --save-dev 将产品的开发环境需要的依赖模块添加到 package.json 的 devDependencies 中,只在开发时才用到,发布后用不到它。

    题目4: node_modules的查找路径是怎样的?

    当require('xxx'),这个模块的xxx不是nodejs的内建模块(比如http、path、fs等),并且模块标识不以路径开始('../ , ./')。
    则nodejs会不断的上一级目录递归查找node_modules目录,若一直未找到模块的xxx,则会抛错。

    题目5: npm3与 npm2相比有什么改进?yarn和 npm 相比有什么优势? (选做题目)

    npm3的对npm2优化点在于对于以字母序安装npm包的时候,优先安装在node_modules第一层级目录。这样做的好处是如果后续包有相关依赖则不需要重复安装。

    题目6: webpack是什么?和其他同类型工具比有什么优势?

    webpack是一种模块加载器兼打包工具,可以将各种资源;例如JS(含JSX)、coffee、样式(含less/sass)、图片等都作为模块来使用和处理。

    webpack

    优势:

    • webpack以 commonJS 的形式来书写脚本滴,但对 AMD/CMD 的支持也很全面,很方便旧项目进行代码迁移。
    • 能被模块化的不仅仅是 JS 了,还有CSS、图片静态资源等等
    • 开发便捷,能替代部分 grunt/gulp 的工作,比如打包、压缩混淆、图片转base64等。

    题目7:npm script是什么?如何使用?

    npm script 是package.json的一个属性,可以在scripts里面定义一些脚本命令,一般使用npm run xxx执行。如:

    "script" : {
      "new": "mkdir test"           //新建一个test文件夹
    }
    

    执行命令:npm run new

    题目8: 使用 webpack 替换 入门-任务15中模块化使用的 requriejs

    webpack-demo
    代码

    题目9:gulp是什么?使用 gulp 实现图片压缩、CSS 压缩合并、JS 压缩合并]

    gulp是一种基于流的前端构建工具,可以实现流程化的对代码进行检测,压缩,修改,打包等,而不必在每个步骤分别去处理文件,大大地减少了处理时间。

    使用:
    1、安装gulp

    npm install -g gulp
    npm install --save-dev gulp
    

    2、项目根目录下新建一个gulpfile.js文件

    var gulp = require('gulp');
    var cssnano = require('gulp-cssnano');
    var uglify = require('gulp-uglify');
    var imgmin = require('gulp-imagemin');
    var concat  = require('gulp-concat');
    //当我们需要使用一个功能时,需要先在bash安装这个模块,
    //然后在使用前require它,最后在gulp.task中定义这个功能。
    
    //图片压缩
    gulp.task('imagemin',function(){
      return gulp.src('图片地址')
      .pipe(imagemin())
      .pipe(gulp.dest('输出目录')
    })
    
    
    //css压缩合并
    gulp.task('cssnano',function(){
      return gulp.src([css1地址,css2地址...])
      .pipe(cssnano())       //压缩
      .pipie(concat(新文件名))  //合并
      .pipe(gulp.dest(输出目录))
    })
    
    
    //js压缩合并
    gulp.task('uglify',function(){
      return gulp.src([js1地址,js2地址,....])
      .pipe(uglify())      //压缩
      .pipie(concat(新文件名))   //合并
      .pipe(gulp.dest(输出目录))
    })
    

    相关文章

      网友评论

          本文标题:webpack基础知识

          本文链接:https://www.haomeiwen.com/subject/qbqscxtx.html