Vue項目打包常見問題

vue的前端項目中,有時候需要多個不同項目合并到一起。有時候有一些特殊要求。

1、打包后不允許生成帶 .map的文件

正常使用npm run build命令打包生成的dist文件中,js文件總會生成一個同名的.map文件,原因如下:

?總結?:Vue項目生成.map文件是Webpack為支持源碼級調試而設計的默認行為,需權衡調試需求與安全/性能因素后,通過配置決定是否保留。

控制生成策略:通過配置vue.config.js中的productionSourceMap: false可完全禁用.map文件生成。該設置會關閉Webpack的Source Map生成邏輯,使最終輸出僅包含壓縮后的業務代碼。保留.map文件時建議通過服務器權限設置禁止外部訪問。

  1. ?源碼映射功能?
    .map文件是Source Map文件,用于建立壓縮后的生產環境代碼與原始開發代碼的對應關系。當代碼經過Webpack打包處理后,所有代碼會被壓縮、混淆和加密,此時.map文件可幫助將錯誤定位到原始代碼的具體行和列。

  2. ?調試支持強化?
    開發階段生成的.map文件能讓瀏覽器開發者工具展示未壓縮前的源碼結構,支持斷點調試和變量跟蹤。生產環境保留.map文件可輔助遠程錯誤診斷,但存在源碼泄露風險。

  3. ?構建工具默認行為?
    Vue CLI默認在生產構建時啟用productionSourceMap選項(值為true),導致Webpack自動生成.map文件。該配置繼承自Webpack的devtool設定,針對不同環境生成不同類型的Source Map。

  4. ?文件體積與安全影響?
    .map文件通常占打包體積的50%以上,可能影響加載性能。同時,攻擊者可通過工具(如reverse-sourcemap)利用.map文件反編譯出項目源碼,引發安全風險。

解決:在vue.config.js文件中,增加節點:

?configureWebpack:config => {config.devtool=config.mode==='production'?false:'source-map';},

2、打包后config.js命名沖突

解決:直接將文件重命名

在引用的index.html中將引用配置文件重命名,在代碼中,將config.js,重命名

3、打包手的文件中,不允許xx.xx.js的文件(即文件名不能出現多個.)

解決:在vue.config.js文件中,增加節點:

?filenameHashing: false,configureWebpack: {output: {filename: '[name].js',chunkFilename: '[name].js',},

4、打包后app.js命名沖突

解決:在上述配置中,將文件添加前綴或后綴

filenameHashing: false,configureWebpack: {output: {filename: 'js/ss_[name].js',chunkFilename: 'js/[name].js',},

注:也可以將1、4兩項配置合并:

 filenameHashing: false,configureWebpack: {output: {filename: 'js/ss_[name].js',chunkFilename: 'js/[name].js',},devtool:process.env.NODE_ENV==='production'?false:'source-map'},

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

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

相關文章

Linux 學習-模擬實現【簡易版bash】

1、bash本質 在模擬實現前,先得了解 bash 的本質 bash 也是一個進程,并且是不斷運行中的進程 證明:常顯示的命令輸入提示符就是 bash 不斷打印輸出的結果 輸入指令后,bash 會創建子進程,并進行程序替換 證明&#x…

GitHub 趨勢日報 (2025年05月31日)

📊 由 TrendForge 系統生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日報中的項目描述已自動翻譯為中文 📈 今日獲星趨勢圖 今日獲星趨勢圖 1153 prompt-eng-interactive-tutorial 509 BillionMail 435 ai-agents-for-begin…

“人單酬“理念:財稅行業的自我驅動革命

引言:當薪酬不再是"固定數字",而是"成長標尺" "為什么有人拼命工作卻收入停滯?為什么企業總在人才流失中掙扎?"這些問題背后,往往隱藏著傳統薪酬體系的僵化。而"人單酬"&…

AI大模型賦能,aPaaS+iPaaS構建新一代數智化應用|愛分析報告

01 aPaaS和iPaaS成為企業用戶關注重點 PaaS市場定義 根據Gartner的定義,PaaS(Platform as a Service)平臺是應用基礎架構(中間件)服務的廣泛集合, 包含應用平臺、集成、業務流程管理、數據服務和AI應用等…

WPS快速排版

論文包括(按順序):封面(含題目)、摘 要、關鍵詞、Abstract(英文摘要)、Keywords、目錄、正文、參考文獻、在讀期間發表的學術論文及研究成果,致 謝 題目(黑小一加粗&…

python第39天打卡

1.灰度圖像 作為圖像數據,相較于結構化數據(表格數據)他的特點在于他每個樣本的的形狀并不是(特征數,),而是(寬,高,通道數) # 先繼續之前的代碼 import torch import torch.nn as nn import t…

win11小組件功能缺失的恢復方法

問題說明:重置了win11系統,結果小組件功能找不到了,最后用以下辦法解決。 1. 以管理員身份打開 PowerShell 或 CMD。 2. 運行以下命令: winget install 9MSSGKG348SP 注:如果報錯,可嘗試先卸載再安裝…

Kali Linux從入門到實戰:系統詳解與工具指南

一、Kali Linux簡介 Kali Linux是一款基于Debian的Linux發行版,專為滲透測試和網絡安全審計設計,由Offensive Security團隊維護。其前身是BackTrack,目前集成了超過600款安全工具,覆蓋滲透測試全流程,是網絡安全領域…

C語言 — 文件

目錄 1.流1.1 流的概念1.2 常見的的流 2.文件的打開和關閉2.1 fopen函數2.2 fclose函數2.3 文件的打開和關閉 3.文件的輸入輸出函數3.1 fputc函數3.2 fgetc函數3.3 feof函數和ferror函數3.4 fputs函數3.5 fgets函數3.6 fwrite函數3.7 fread函數3.8 fprintf函數3.9 fscanf函數 4…

Pull Request Integration 拉取請求集成

今天我想要把我創建的項目,通過修改yaml里面的內容,讓我在main分支下的其他分支拉取請求的時候自動化測試拉取的內容,以及將測試結果上傳到控制臺云端。 首先我通過修改yaml文件里面的內容 name: Build and Teston:push:branches:- mainjobs:…

NodeJS全棧開發面試題講解——P3數據庫(MySQL / MongoDB / Redis)

3.1 如何用 Node.js 連接 MySQL?你用過哪些 ORM? 面試官您好,我先介紹如何用 Node.js 連接 MySQL,然后補充我常用的 ORM 工具。 🔌 原生連接 MySQL 使用 mysql2 模塊: npm install mysql2 const mysql …

Redis最佳實踐——性能優化技巧之數據結構選擇

Redis在電商應用中的數據結構選擇與性能優化技巧 一、電商核心場景與數據結構選型矩陣 應用場景推薦數據結構內存占用讀寫復雜度典型操作商品詳情緩存Hash低O(1)HGETALL, HMSET購物車管理Hash中O(1)HINCRBY, HDEL用戶會話管理Hash低O(1)HSETEX, HGET商品分類目錄Sorted Set高O…

題單:最大公約數(輾轉相除法)

題目描述 所謂 “最大公約數(GCD)” ,是指所有公約數中最大的那個,例如 12 和 1818 的公約數有 1,2,3,6 ,所以 12 和 18 的最大公約數為 6 。 輾轉相除法,又名歐幾里德算法(Euclidean Algorit…

hadoop完整安裝教程(附帶jdk1.8+vim+ssh安裝)

本篇帶領大家在uabntu20虛擬機上安裝hadoop,其中還包括jdk1.8、ssh、vim的安裝教程,(可能是)史上最全的安裝教程!!!若有疑問可以在評論區或者私信作者。建議在虛擬機上觀看此博客,便…

Flutter、React Native、Unity 下的 iOS 性能與調試實踐:兼容性挑戰與應對策略(含 KeyMob 工具經驗)

移動端跨平臺開發逐漸成為常態,Flutter、React Native、Unity、Hybrid App 等框架在各類 iOS 項目中頻繁出現。但隨之而來的,是一系列在 iOS 設備上調試難、性能數據采集難、日志整合難的問題。 今天這篇文章,我從實際項目出發,聊…

PyCharm接入DeepSeek,實現高效AI編程

介紹本土AI工具DeepSeek如何結合PyCharm同樣實現該功能。 一 DeepSeek API申請 首先進入DeepSeek官網:DeepSeek 官網 接著點擊右上角的 “API 開放平臺“ 然后點擊API keys 創建好的API key,記得復制保存好 二 pycharm 接入deepseek 首先打開PyCh…

Cinnamon開始菜單(1):獲取應用數據

看了半天:/usr/share/cinnamon/applets/menucinnamon.org,終于挖到了精髓。 Cinnamon.AppSystem.get_default() 獲取系統應用數據 get_tree() 獲取樹機構 get_root_directory() 獲取根目錄 iter() 遍歷 get_name() 獲取名稱 get_desktop_file_id()…

git reset --hard HEAD~1與git reset --hard origin/xxx

git reset --hard HEAD~1與git reset --hard origin/xxx git reset --hard origin/xxx有時候會太長,手工輸入略微繁瑣,可以考慮: git reset --hard HEAD~1 替代。 或者使用這種方式 git reset撤銷當前分支所有修改,恢復到最近一…

鴻蒙OSUniApp PWA開發實踐:打造跨平臺漸進式應用#三方框架 #Uniapp

UniApp PWA開發實踐:打造跨平臺漸進式應用 前言 在過去的一年里,我們團隊一直在探索如何利用UniApp框架開發高性能的PWA應用。特別是隨著鴻蒙系統的普及,我們積累了不少有價值的實踐經驗。本文將分享我們在開發過程中的技術選型、架構設計和…

ansible自動化playbook簡單實踐

方法一:部分使用ansible 基于現有的nginx配置文件,定制部署nginx軟件,將我們的知識進行整合 定制要求: 啟動用戶:nginx-test,uid是82,系統用戶,不能登錄 啟動端口82 web項目根目錄/…