码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Vue Webpack介绍及安装


    文章目录

      • 1 Webpack介绍及安装
      • 2 webpack起步
      • 3 webpack配置
      • 4 loader
        • 4.1 css-loader、style-loader
        • 4.2 less-loader
      • 5 webpack图片文件处理
      • 6 webpack使用vue的配置

    1 Webpack介绍及安装

    https://webpack.js.org/concepts/

    https://www.webpackjs.com/

    • 本质上来讲,webpack是一个现代的JavaScript应用的静态模块打包工具

    安装:

    • 首先要安装Node.js、版本大于8.9

    • 查看node版本

    node -v
    
    • 1
    • 全局安装webpack(指定3.6.0、因为vue cli2依赖该版本)
    npm install webpack@3.6.0 -g
    
    • 1
    • 局部安装
    cd 对应目录
    npm install webpack@3.6.0 --save-dev
    
    • 1
    • 2
    • 为什么全局安装后,还需要局部安装呢?
    1. 在终端直接执行webpack命令,使用全局安装的webpack

    2. 当package.json中定义了scripts时时,其中包含了webpack命令,那么使用的是局部webpack

    2 webpack起步

    打包

    webpack ./src/main.js ./dist/bundle.js
    
    • 1

    3 webpack配置

    webpack.config.js

    // 使用node的包path
    // 初始化: npm init
    const path = require('path')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname,'dist'),// 当前文件绝对路径
        filename: 'bundle.js'
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    打包

    webpack
    
    • 1

    使用脚本

    # 初始化
    npm init
    # 安装package-lock.json中的依赖
    npm install
    
    • 1
    • 2
    • 3
    • 4

    package.json文件中scripts存放脚本,可以自定义

    {
      "name": "meetwebpack",
      "version": "1.0.0",
      "description": "",
      "main": "index.js",
      "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
        "build": "webpack"
      },
      "author": "",
      "license": "ISC",
      "devDependencies": {
        "webpack": "^3.6.0"
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    
    # 测试脚本
    
    npm run test
    # 打包
    npm run build
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    4 loader

    4.1 css-loader、style-loader

    1. 通过npm安装需要使用的loader

    https://www.webpackjs.com/loaders/css-loader/

    安装cssl和style的loader

    npm install --save-dev css-loader
    npm install style-loader@2.0.0 --save-dev
    
    • 1
    • 2

    file.js

    import css from 'file.css';
    
    • 1

    webpack.config.js

    module.exports = {
      module: {
        rules: [
          {
            test: /\.css$/,
            use: [ 'style-loader', 'css-loader' ]
          }
        ]
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    1. 在webpack.config.js中module关键字下进行配置

    4.2 less-loader

    npm install --save-dev less-loader less
    
    • 1

    5 webpack图片文件处理

    url-loader

    npm install --save-dev url-loader
    
    {
      test: /\.(png|jpg|gif)$/,
      use: [
        {
          loader: 'url-loader',
          options: {
            limit: 8192
          }
        }
      ]
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    css

    body {
        /*background-color: pink;*/
        background: url("../img/1.jpg");
    }
    
    • 1
    • 2
    • 3
    • 4

    6 webpack使用vue的配置

    npm install vue --save
    
    • 1

    webpack.config.js

    // 指定查找vue的路径
    resolve:{
      // alias: 别名
      alias:{
        'vue$':'vue/dist/vue.esm.js'
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    main.js

    // 5.使用vue进行开发
    import Vue from 'vue'
    
    const app = new Vue({
      el: '#app',
      data: {
        message: '你好'
      }
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    npm install vue-loader@15.4.2 vue-template-compiler@2.5.21 --save-dev
    
    • 1

    代码地址:
    https://github.com/courageSteak/vue-framework

    作者:有勇气的牛排
    https://www.couragesteak.com/article/158

  • 相关阅读:
    ASP.NET第五章 Application、Session和Cookie对象
    Gateway学习和源码解析
    【JAVA基础】【查漏补缺】07 - 集合Collection和单列集合List
    (六)Ansible-Template
    Java8 Stream API 基础操作
    Leetcode 1417. Reformat The String
    齐普夫定律在循环神经网络中的语言模型的应用
    21天学Python --- 打卡2:Regular Expression
    HCNP Routing&Switching之代理ARP
    初次使用IntelliJ IDEA从零开始学习创建maven项目
  • 原文地址:https://blog.csdn.net/zx77588023/article/details/128164944
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号