webpack開發Vue配置

一直以來使用webpack都是用的別人的配置,這幾天自己學習了一下。

項目地址:https://github.com/donghaohao...

新建整個工程

  1. npm init

  2. 安裝依賴,這里我們開發vue項目,npm install vue --save,然后是開發時的依賴npm install --save-dev

  3. 這里有個重點是寫package.json里面的scripts,因為我們要分開發環境和生產環境。開發環境使用webpack-dev-server熱替換,生產環境需要壓縮,加hash等。使用npm run dev 或 npm run build 就可以運行下面的腳本。

    "dev": "webpack-dev-server --inline --hot --compress --history-api-fallback --config webpack.dev.config.js","build": "webpack --progress --hide-modules --config webpack.prod.config.js"

配置

這里分為三個:webpack.base.config.js webpack.dev.config.js webpack.prod.config.js

  1. entry設置入口文件,可以設置多個,就會打包成多個,vendors是我們如果引用了vue,jQuery等,就不會把這些和代碼打包到一起,會另外生成vendor.js。

    entry: {main: './src/index.js',vendors: ['vue']
    },
  2. 輸出目錄,這里path是最后打包完的輸出目錄,publicPath是server上的目錄,這個自行設置好路徑。我們在開發模式的時候并不會輸出到目錄的。

  3. webpack主要就是各種loader,這個可以參考我的github上的,需要解釋的有兩點,一是使用vue-loader時,因為需要使用postcss,所以下面需要這樣寫:

      vue: {autoprefixer: false,postcss: [nested(),cssnext({ browsers: ['last 2 versions', 'Android >= 2.1', 'iOS >= 7.0'] }),flexFallback(),],},

    二個就是使用url-loader時,它會自動在圖片后面加hash,強迫癥患者表示不行,我們在開發模式下不加,生產模式下加。

    // 開發模式
    config.module.loaders.push({test: /\.(gif|jpg|png|jpeg|svg)\??.*$/, loader: 'url-loader?name=[name].[ext]&limit=8192'
    });
    // 生產模式
    config.module.loaders.push({test: /\.(gif|jpg|png|jpeg|svg)\??.*$/, loader: 'url-loader?limit=8192'
    });
  4. preLoaders 就是提前處理,這里我們使用了eslint,需要檢查書寫規范,然后添加 .eslintrc 文件.

  5. resolve,extensions就是你require的時候可以省略擴展名,alias就是別名,在require的時候直接使用別名,避免寫的太長。

    resolve: {// 擴展,require時省略擴展名extensions: ['', '.js', '.vue'],// 別名alias: {filter: path.join(__dirname, './src/filters'),components: path.join(__dirname, './src/components')}}
  6. 插件

    • ExtractTextPlugin 提取CSS。

    • HtmlWebpackPlugin 生產html,這個可以自己生成也可以指定模板,會將打包的js和css插入到html中,這個有好多其他參數,可自行搜索。

    • webpack.optimize.CommonsChunkPlugin 這個為了抽取前面vendor里的第三方庫,打包成另外的文件。

    • webpack.optimize.UglifyJsPlugin 壓縮代碼。(生產模式)

    • CleanWebpackPlugin 這個是我最新發現的一個,主要是在打包到dist之前先刪除以前的dist,因為加hash厚并不會覆蓋。(生產模式)

  7. 這里使用了ES6,所以要配置一下.babelrc。

增加項目文件

這里我只是增加了一些測試的項目文件,開發和生產都正常,如有需要可以自行添加其他目錄。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/284001.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/284001.shtml
英文地址,請注明出處:http://en.pswp.cn/news/284001.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ABP詳細教程——模塊類

概述模塊化是ABP vNext的最大亮點,也是ABP vNext框架的核心,而模塊類是ABP vNext框架模塊化的核心要素。這一章節,我就從模塊類的用法、運行機制、源代碼等層面,帶大家詳細了解ABP vNext的模塊類。用法在ABP的約定中,每…

[轉]Eureka工作原理

目錄 Eureka 工作原理 Eureka 核心概念 自我保護機制 Eureka 集群原理 Eurka 工作流程 總結 Eureka 工作原理 上節內容為大家介紹了,注冊中心 Eureka 產品的使用,以及如何利用 Eureka 搭建單臺和集群的注冊中心。這節課我們來繼續學習 Eureka&…

centos7下別名(alias)的特殊用法

版權聲明:轉載請注明出處:http://blog.csdn.net/dajitui2024 https://blog.csdn.net/dajitui2024/article/details/79438200 參考:https://www.cyberciti.biz/faq/bash-bypass-alias-command-on-linux-macos-unix/ 正常情況下,定義過的別名&a…

解決WDCP3環境gbk網站編碼程序亂碼問題

因為默認WDCP V3版本環境編碼格式是UTF-8版本,如果我們程序采用的是GBK編碼肯定都會有亂碼問題。 我們到WDCP后臺,"網站管理"-"PHP設置",看到上圖所示,準備直接在線編輯PHP.INI文件。 這里我們找到"defa…

重談聯想5G編碼投票事件

此前,司馬南談了聯想好幾個問題,其中最尖銳的要屬國有資產流失,這是聯想管理層無法回避的死穴。不過,司馬南批判聯想5G投票背刺H公司,這基本就是造謠了。當年,媒體把編碼投票炒作的很厲害,抨擊聯…

JStorm2.1.1集群的安裝和使用

為什么80%的碼農都做不了架構師?>>> JStorm2.1.1集群的安裝和使用 Storm是一個免費開源、分布式、高容錯的實時計算系統,而JStorm是阿里巴巴開源的基于Storm采用Java重寫的一套分布式實時流計算框架,在性能和支持的集群規模上做了…

Hystrix 原理

Hystrix是什么? Hystrix是Netflix開源庫,這是一個針對分布式系統的延遲和容錯庫。 Hystrix 供分布式系統使用,提供延遲和容錯功能,隔離遠程系統、訪問和第三方程序庫的訪問點,防止級聯失敗,保證復雜的分布…

「深度」無人機實名制政策特稿|市場看好、資本關注,“反黑飛”正在崛起

從政策和需求來看,“反黑飛”越來越重要,市場也正在不斷崛起。 對于大多數人來說,今天是最適合明目張膽“裝嫩”的六一兒童節。不過,在無人機廠商和無人機玩家的眼里,今天是無人機實名制政策正式實施的日子。 近年來&…

在navicat中新建數據庫

前言: 在本地新建一個名為editor的數據庫; 過程: 1.; 2.選擇:utf8mb4 -- UTF-8 Unicode字符集,原因在于:utf8mb4兼容utf8,且比utf8能表示更多的字符。,而且它支持表情符號…

MASA Stack 第三期社區例會

MASA Blazor 0.5.0發版內容功能Autocomplete:支持通過設置AutoSelectFirst參數開啟自動選擇第一項的功能,支持CacheItems參數,增強使用上下鍵的用戶體驗。BottomNavigation::一個替代側邊欄的新組件。它主要用于移動應…

MySQL添加用戶、刪除用戶與授權

MySql中添加用戶,新建數據庫,用戶授權,刪除用戶,修改密碼(注意每行后邊都跟個;表示一個命令語句結束): 1.新建用戶 1.1 登錄MYSQL: >mysql -u root -p >密碼 1.2 創建用戶: mysql> insert into mysql.user(Host,User,Password) values("lo…

[轉]高并發架構設計之--「服務降級」、「服務限流」與「服務熔斷」

目錄 服務降級 1 、簡介 2 、使用場景 3 、核心設計 3.1 分布式開關 3.2 自動降級分類 3.3 配置中心 3.4 處理策略 3.5 降級分類 3.6 服務降級要考慮的問題 4 、高級特性 4.1 分級降級 4.2 降級權值 5 、總結與展望 服務限流 一、為什么要做服務限流設計&…

【Linux】【Services】【nfs】nfs安裝與配置

1. 概念 1.1. NFS:Network File System,傳統意義上,文件系統在內核中實現。 1.2. RPC:Remote Procedure Call protocol,遠程過程調用,函數調用(遠程主機上的函數) 1.3. 端口&#xf…

SpringBoot獲取ApplicationContext

2019獨角獸企業重金招聘Python工程師標準>>> 有兩種方法: 創建Component實現ApplicationContextAware接口,SpringBoot會自動調用這個類的setApplicationConext()方法。鼓勵使用這種方式。SpringApplication.run(MyApplication.class, args)這…

SkiaSharp 之 WPF 自繪 投籃小游戲(案例版)

此案例主要是針對光線投影法碰撞檢測功能的示例,順便做成了一個小游戲,很簡單,但是,效果卻很不錯。投籃小游戲規則,點擊投籃目標點,就會有一個球沿著相關拋物線,然后,判斷是否進入籃…

zuul集成ribbon完成服務通信和負載均衡

目錄 Zuul2服務通信 超時相關 默認超時配置 自定義超時配置 負載均衡 Zuul2服務通信 描述:zuul2通過Ribbon完成客戶端負載均衡以及與服務器群集進行通信。 zuul2的通信是集成Ribbon實現的,在Origin中集成Ribbon基本配置(例如IClientCo…

時任上海來伊份互聯網事業群總裁王戈鈞 :傳統企業(線上+線下)移動互聯網改造...

2017年12月22日-23日,第13屆信息化領袖峰會暨2017中國數字化貢獻人物頒獎盛典在上海盛大開幕。本次峰會由上海市經濟和信息化委員會指導,上海市國有資產信息中心、上海市計算機用戶協會、上海市信息服務業行業協會、上海大數據聯盟、上海市高等教育學會支…

Linux系統時間\硬件時間(date、tzselect、clock、hwclock、ntpdate)

1、系統時間和硬件時間 在Linux中有硬件時鐘與系統時鐘兩種時鐘。硬件時鐘是指主機板上的時鐘設備,也就是通常可在BIOS畫面設定的時鐘。系統時鐘則是指kernel中的時鐘。所有Linux相關指令與函數都是讀取系統時鐘的設定。因為存在兩種不同的時鐘,那么它們…

C#------如何判斷輸入的是否為純數字

private void Btn_OK_Click(object sender, EventArgs e){IDormitoryAdminCardService aservice new DormitoryAdminCardService();string text this.CardNoEdit.Text;//判斷是否輸入的是純數字string pattern "^[0-9]*$";Regex regex new Regex(pattern);if (re…

【.NET6+Modbus】Modbus TCP協議解析、仿真環境以及基于.NET實現基礎通信

接下來的內容,我會以從頭開發一個簡單的基于modbus tcp通信的案例,來實現一個基礎的通信功能。有關環境:開發環境:VS 2022企業版運行環境:Win 10 專業版.NET 環境版本:.NET 6【備注】 源碼在文末 1、新建一…