webpack

作者: littlesiqi | 来源:发表于2017-12-22 01:21 被阅读0次
    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

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