Package.json詳解

来源:https://www.cnblogs.com/rong88/archive/2019/10/12/11664337.html
-Advertisement-
Play Games

引言 前端需要學習的東西真的挺多的,之前主要從事的是MVC框架,操作DOM,使用JQUERY比較多,不知到什麼時候,發現現在前端MVVM是主流,不得不把之前的大部分東西丟掉,作為前端嬰兒不斷前行。 所以以後的文章,可能開始都比較基礎,希望大拿不要見笑,若有不對的地方,希望指正,我也會不斷修正迭代。 ...


引言

前端需要學習的東西真的挺多的,之前主要從事的是MVC框架,操作DOM,使用JQUERY比較多,不知到什麼時候,發現現在前端MVVM是主流,不得不把之前的大部分東西丟掉,作為前端嬰兒不斷前行。

所以以後的文章,可能開始都比較基礎,希望大拿不要見笑,若有不對的地方,希望指正,我也會不斷修正迭代。

 

在學習MVVM(react和vue)的時候,開始就是會找iview,element,ant-pro等現成的東西,去改。CLI直接安裝,也沒有想去學習webpack。現在看更早一點的自己,真的是傻的可愛,就是那種沒有方法的新手,弄出來完事。真的要專註一個領域,還是要每個方面都要研究透,要有邏輯的思考。

以下,就是在工作過程中,自己提問題,自己找答案的。有時候覺得挺有趣,看著看著,發現原來npm指令是這樣來的,那不僅要弄清楚webpage,npm後續也要多學習。在程式里,任何東西都是有關聯的。

生命不息,行走不止,學習不停。

 

1.概念

Node.js項目遵循模塊化的架構,當我們創建了一個Node.js項目,意味著創建了一個模塊,這個模塊的描述文件,被稱為package.json

亦即:模塊的描述文件 = package.json

 

2.屬性

name:包名

version:版本號

main  入口文件

license:項目許可

scripts:聲明一系列npm腳本指令

dependencies:項目在生產環境中依賴的包-install的東西

devDependencies:項目在開發和測試環境中依賴的包

repository: 項目代碼存放地方(git地址)

 

3.生成

自己生成package.json,在項目根目錄下麵npm init即可

另,解決了一個疑問,安裝項目的時候,用的命令為什麼不同?什麼時候用npm run dev,什麼時候用npm start ?

答案:看 scripts

"scripts": {

    "start": "set NODE_ENV='development' && webpack-dev-server --inline --progress --config ./build/webpack.config.development.js",

    "build": "set NODE_ENV='development' && webpack --config ./build/webpack.config.production.js"

  },

在package.json的script裡面看配置的腳本指令,再查看對應的文件。

start裡面可以看到埠;build打包編譯,start,啟動

有點小開心哦!嗯,明白了!

 

引申:package-lock.json

  1. package.json文件記錄你項目中所需要的所有模塊。當你執行npm install的時候,node會先從package.json文件中讀取所有dependencies信息,然後根據dependencies中的信息與node_modules中的模塊進行對比,沒有的直接下載,已有的檢查更新(最新版本的nodejs不會更新,因為有package-lock.json文件,下麵再說)。另外,package.json文件只記錄你通過npm install方式安裝的模塊信息,而這些模塊所依賴的其他子模塊的信息不會記錄。
  2. package-lock.json文件鎖定所有模塊的版本號,包括主模塊和所有依賴子模塊。當你執行npm install的時候,node從package.json文件讀取模塊名稱,從package-lock.json文件中獲取版本號,然後進行下載或者更新。因此,正因為有了package-lock.json文件鎖定版本號,所以當你執行npm install的時候,node不會自動更新package.json文件中的模塊,必須用npm install packagename(自動更新小版本號)或者npm install [email protected](指定版本號)來進行安裝才會更新,package-lock.json文件中的版本號也會隨著更新。
  3. 附:當package.json與package-lock.json都不存在,執行"npm install"時,node會重新生成package-lock.json文件,然後把node_modules中的模塊信息全部記入package-lock.json文件,但不會生成package.json文件,此時,你可以通過"npm init --yes"來初始化生成package.json文件。

總結:

  • 項目中引入的包版本號之前經常會加^號,每次在執行npm install之後,下載的包都會發生變化,為了系統的穩定性考慮,每次執行完npm install之後會創建或者更新package-lock文件。該文件記錄了上一次安裝的具體的版本號,相當於是提供了一個參考,在出現版本相容性問題的時候,就可以參考這個文件來修改版本號即可。
  • 重新install刪掉lock

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • flutterBoost使用筆記 新一代Flutter-Native混合解決方案。 FlutterBoost是一個Flutter插件,它可以輕鬆地為現有原生應用程式提供Flutter混合集成方案。FlutterBoost的理念是將Flutter像Webview那樣來使用。在現有應用程式中同時管理Na ...
  • 如需轉載,請註明出處:Flutter學習筆記(29)--Flutter如何與native進行通信 前言:在我們開發Flutter項目的時候,難免會遇到需要調用native api或者是其他的情況,這時候就需要處理Flutter與native的通信問題,一般常用的Flutter與native的通信方式 ...
  • 文本控制項 Text 支持兩種類型的文本展示,一個是預設的展示單一樣式文本 Text,另一個是支持多種混合樣式的富文本 Text.rich。 單一樣式文本 Text 單一樣式文本 Text 的初始化,是要傳入需要展示的字元串。而這個字元串的具體展示效果,受構造函數中的其他參數控制。這些參數大致可以分為 ...
  • 如需轉載,請註明出處:Flutter學習筆記(28)--使用第三方jar包 1.打開一個Flutter項目,點擊編碼視窗右上角的Open for Editing in Android Studio,這時候你的Flutter項目會轉換成一個Android結構的項目。 2.項目的目錄結構選擇projec ...
  • 1、背景 近期,公司希望實現安卓原生端的PDF功能,要求:高效、實用。 經過兩天的調研、編碼,實現了一個簡單Demo,如上圖所示。 關於安卓原生端的PDF功能實現,技術點還是很多的,為了咱們安卓開發的同學少走彎路,通過此文章,簡單講解下Demo的實現原理和主要技術點,並附上源碼。 2、安卓PDF現狀 ...
  • 需求 自適應大小的文本: 效果圖: 項目開發中,開發人員根據UI人員提供的一套尺寸,佈局了一些帶文本的頁面, 往往會少考慮一些數據極限的問題,造成機型屏幕適配問題。 例如: 文本(或數值)長度可變,如經驗值、金幣數量等,如果頁面同一高度使用了多個Textview佈局擺放,當Textview文本長度增 ...
  • 升級了iOS 13,發現代碼中使用presentViewController的都變成了這樣的,頂部留了一部分 查看present樣式,iOS 13 預設自動適配,需要在present的時候,設置style ...
  • 1)HTML的基本概念 HTML就一種描述性的標記語言,是文檔的超文本標記語言。 基本結構為: HTML標記組成 : <標記元素> 源文件中標記是不區分大小寫的。 2)編寫方法: 1》dreamweaver 或者其他的工具如sublime等。 3)瀏覽HTML文件,查看源代碼。右鍵點擊網頁,選擇查看 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...