webpack

  1. 全局安装 nrm: npm install nrm -g

    1. 查看镜像源 nrm ls
    2. 切换淘宝镜像源 nrm use taobao
    3. 全局安装webpack npm install webpack@1.14.0 -g
      2.4. webpack 进行代码打包

    导出一个模块 module.exports = 需要导出的对象

    导入一个模块 var 模块名 = require(文件路径)

    webpack 打包命令
    webpack 需要打包的文件名 输出的文件名

    例如:
    webpack main.js build.js
    2.5. webpack 配置文件

    1. 默认配置文件名称webpack.config.js

    module.exports = {
    entry:'需要打包的文件' // 路径+文件名 一般为 ./src/xxx.js
    output:{
    path:'输出文件的路径' // 绝对路径 使用__dirname + 路径
    filename:*输出文件的名称* // 一般都为build.js/bundle.js
    }
    }

    1. 使用webpack进行打包
      - 如果是默认配置文件 则直接在命令行中 输入 webpack
      - 如果是其他改过名字的配置文件 则使用 webpack --config 配置文件名
      2.6. webpack loader的使用

loader:预处理器。在js代码执行之前需要执行的一些处理。
2.6.1. css-loader

css-loader 是进行css解析,能够使浏览器正常识别js文件中导入的 css 文件
1. 初始化package.json
npm init

2. 安装css-loader以及style-loader
npm install style-loader css-loader --save-dev

3. 在webpack.config.js文件中进行配置

        module:{
                loaders:[
                        {
                                test: /\.css$/,
                                loader:'style-loader!css-loader'
                        }
                ]
        }

2.6.2. sass-loader 的使用

sass-loader是进行scss文件的解析
1. 安装sass-loader
npm install node-sass sass-loader style-loader css-loader --save-dev

2.配置sass-loader
 loaders:[
                {
                        test: /\.scss$/,
                        loader:'style-loader!css-loader!sass-loader'
                } 
        ]

2.6.3. less-loader 的使用

less-loader是进行less文件的解析
1. 安装scss-loader
npm install less less-loader style-loader css-loader --save-dev

2.配置scss-loader
 loaders:[
                {
                        test: /\.less$/,
                        loader:'style-loader!css-loader!less-loader'
                }
        ]

2.6.4. url-loader 的使用

url-loader是进行url资源的解析
1. 安装url-loader
npm install file-loader url-loader --save-dev

2.配置url-loader
 loaders:[
                {
                        test: /\.(png|jpg|gif|ttf)$/,
                        loader:'url-loader!limit=20000&name=images/[hash:8].[name].[ext]'
                        // limit单位是字节 1kb = 1024b(字节)
                        // 对于比较小的图片资源可以使用limit进行限制 
                        // 小于limit值转换成base64字符串内嵌到js代码中
                        // 大于limit值的图片才转成URL进行网络请求
                }
        ]

2.6.5. webpac-dev-server的使用

1. 安装webpack-dev-server

npm install webpack@1.14.0 webpack-dev-server@1.16.0 --save-dev

2. 安装自动生成HTML文件的插件
npm install html-webpack-plugin@2.28.0 --save-dev

3. 修改package.json文件

        "scripts": {
                "dev": "webpack-dev-server --hot --inline --open --port 5008"
        },

4. 配置webpack.config.js中的内容

- 引入html-webpack-plugin
        `var htmlWP = require('html-webpack-plugin');`
- 在modul.exports中加入
         plugins:[
                new htmlWP({
                        title: '首页',  //生成的页面标题
                        filename: 'index.html', //webpack-dev-server在内存中生成的文件名称,自动将build注入到这个页面底部,才能实现自动刷新功能
                        template: 'template.html' //根据template.html这个模板来生成(这个文件程序员自己书写)
                })
        ]

5. 运行 npm run dev

2.6.6. babel-loader的使用

babel-loader是用来将es6语法转换成es5语法
1. 安装babel-loader
npm install babel-core@6.24.0 babel-loader@6.4.1 babel-preset-es2015@6.24.0 babel-plugin-transform-runtime@6.23.0 --save-dev

2. 配置webpack.config.js文件

{
        test: /\.js$/,  // 将.js文件中的es6语法转成es5语法
        loader:'babel-loader',
        exclude:/node_modules/ // 排除node_modules文件夹下的js文件不用被转换
}

3. 配置babel的转码规则

babel:{
        presets:['es2015'],  // 配置将es6语法转换成es5语法
        plugins:['transform-runtime'] // 用来解析vue文件
}

2.7. webpack解析vue文件

2.7.1. 安装vue-loader解析.vue文件

1. 安装相关包
`npm install vue vue-loader@11.3.4 vue-template-compiler babel-plugin-transform-runtime@6.23.0 --save-dev`

2. 配置webpack.config.js文件
{
        test: /.vue$/,  // 解析 .vue 组件页面文件
        loader:'vue-loader' 
}

2.7.2. .vue文件基本代码结构

一个.vue文件就是一个vue的组件
// 1. 组件模板
<template>
<div>

<span v-text="msg" class="red"></span>
</div>
</template>

// 2. 负责导出vue的对象
<script>
        // 负责导出 .vue这个组件对象(它本质上是一个Vue对象,所以Vue中该定义的元素都可以使用)
        export default{  // es6的导出对象的写法
                data(){  //等价于 es5的 data:function(){
                        return {
                                msg :'hello vuejs'
                        }
                },
                methods:{

                },
                created(){

                }
        }
</script>

// 3. 书写组件内部的样式
<style scoped>
// scoped表示这个里面写的css代码只是在当前组件页面上有效,不会去影响到其 他组件页面
        .red{
                color: red;
        }
</style>

2.7.3. 项目入口文件main.js中渲染组件

// 1.0 导入vue核心包
// 凡是使用npm安装的包 引入的时候都不需要写相对路径 只需要写包名即可
import Vue from 'vue';

// 2.0 导入App.vue的vue对象
import App from './App.vue';

// 3.0 利用Vue对象进行解析渲染
new Vue({
        el:'#app',
        render:function(create){return create(App)} //es5的写法
        // render:c=>c(App)  // es6的函数写法 =>:goes to
});

2.8. 使用webpack以及npm创建项目

1. 创建项目文件夹

2. 创建npm的配置文件package.json

npm init -y

3. 创建webpack配置文件(webpack.config.js)

4. 根据项目需求安装所需要使用的模块

npm install 包名 --save-dev
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 webpack介绍和使用 一、webpack介绍 1、由来 ...
    it筱竹阅读 13,845评论 0 21
  • 1.概要 随着越来越多的项目采用 Vue, React, Weex 进行业务开发, 在前端构建方面大多数是用web...
    hubcarl阅读 11,422评论 3 18
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 12,542评论 7 35
  • 目录第1章 webpack简介 11.1 webpack是什么? 11.2 官网地址 21.3 为什么使用 web...
    lemonzoey阅读 5,675评论 0 1
  • 不同材料的物体导热速率不同 【教学目标】 1、通过实验活动,了解不同材料的物体它们的导热速率也不相同。 2、...
    王胜男_阅读 1,144评论 0 0