精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

為什么大多數開發者都答不上這個關于 package.json 的簡單前端面試題

開發 前端
每一個字段, 都在悄悄決定:這個項目是能在面試官的電腦上“一鍵跑起”, 還是在 CI、生產、用戶設備上,一次次翻車。忽視它,它會用最殘忍的方式回擊—— 從 npm start 的第一個報錯開始。理解它,項目的穩定性、可維護性和“面試可通過程度”, 都會肉眼可見地提高一大截。

前端世界從來不缺“教程”:

  • YouTube 教學視頻
  • Udemy 課程
  • Stack Overflow 回答
  • 甚至現在還有 ChatGPT、DeepSeek、Gemini 這一票 AI 助手

上面這些東西,統統已經在那里躺著,隨便點開就是一堆“手把手”。

但真正把人坑哭的,往往不是“不會寫代碼”, 而是——以為自己已經懂了,然后在細節上翻了車。

這篇就是專門拆這種翻車現場的:

  • 哪一步做錯了
  • 現場是什么慘狀
  • 后面是怎么把坑填上的
  • 以及,怎么避免下一次再踩進去

尤其是對初級 / 入門前端來說,有一個事實可能會讓人有點崩潰:

一個不起眼的文件,可以悄無聲息地決定—— 項目到底是跑得飛快,還是直接躺地不起。

這個文件,就是:package.json。

package.json 到底在掌控什么?

對 Node.js、React,甚至任何一個基于 JS 的工程來說, package.json 就是整個項目的“中樞神經”:

  • 所有依賴
  • 所有腳本命令
  • 所有構建入口

統統寫在這里。

一旦它亂了,整個項目就跟著一起垮。

有不少開發者第一次從 GitHub 把項目拉下來, 愉快地敲下:

npm start

然后迎面就是一句:

Error: Cannot find module 'express'

第一反應往往是:

“代碼是不是被改壞了?”

真相卻更簡單殘酷: ——package.json 里根本沒寫上 express 這條依賴。

下面這 9 個點,幾乎覆蓋了前端開發者在 package.json 上最常翻車的場景。

面試問到,一半人答不全; 項目遇到,一半人救不回來。

1. dependencies:撐起線上運行的“主食”

dependencies 這一欄,放的是:

代碼在“生產環境”真正需要的核心庫。

如果這里漏了一條,結果就是:項目壓根跑不起來。

一個正常的寫法,大致是這樣:

{
  "dependencies": {
    "express": "^4.18.2",
    "mongoose": "^8.1.0"
  }
}

常見翻車方式:

  • 本地 npm install 某庫,卻沒用 --save
  • 或者手動改 package.json,卻忘了真正安裝

結果就是經典報錯:

Error: Cannot find module 'package-name'

Fix:

重新安裝,并確保寫回 dependencies:

npm install express --save

或者更現代一點(npm 7+ 默認會寫入):

npm install express

只要記住一句話:


線上要用到的庫,全都該乖乖躺在 dependencies 下面。

2. devDependencies:只活在開發階段的“工具箱”

devDependencies 放的則是另一類東西:

  • 代碼質量工具:ESLint
  • 打包 / 轉譯工具:Babel
  • 測試框架:Jest 等

典型結構如下:

{
  "devDependencies": {
    "eslint": "^8.57.0",
    "jest": "^29.7.0"
  }
}

有些項目的生產事故就卡在這里—— 比如把 ESLint 放進了 dependencies

  • 線上服務器安裝了一堆完全沒必要的開發工具
  • 構建時間肉眼可見地被拖長
  • 鏡像體積也被白白撐大

Fix:

所有“只在開發期用”的東西,都建議用 --save-dev 安裝:

npm install eslint --save-dev

要記住的區分很簡單:

  • 跑業務邏輯、線上必須 → dependencies
  • 輔助開發、跑完就下班 → devDependencies

3. scripts:一個名字寫錯,命令全廢

"scripts" 是 package.json 里最高頻被用到的區域:

{
  "scripts": {
    "start": "node server.js",
    "dev": "nodemon server.js",
    "test": "jest",
    "build": "react-scripts build"
  }
}

NPM 有一條“隱藏規則”

  • npm start 會自動去找 "start" 對應的腳本
  • 如果壓根沒有 "start" 這一項, 那么終端就會一臉冷漠:什么都不會執行

不少新人會出于“好看”或者“自創約定”,把 start 改名:

"run": "node server.js"

然后困惑地問: “為什么 npm start 不動了?”

Fix:

無論腳本再多再花哨,**"start" 一項一定要留著**。 就算只是最簡單的:

"start": "node index.js"

這是 npm 世界里,最基礎、也是最經常被考察的一條共識。

4. type 字段:require 和 import 只能選一邊站

當某個項目在 package.json 里加上:

{
  "type": "module"
}

就等于對 Node.js 宣告:


“這是一個 ES Module 項目。”

緊接著,所有 require() 寫法會被視作“不合法”——

ReferenceError: require is not defined in ES module scope

于是整個項目開始一半 import、一半 require, 到處報錯,哭都不知道從哪兒開始。

Fix 分兩種路線:

如果項目已經大量用 require

  • 暫時不要加 "type": "module"
  • 或者只對部分文件使用 .mjs 擴展名來嘗鮮

如果準備全面擁抱 import/export

  • 把原有的 require / module.exports 逐步遷移
  • 修一修 Node 版本、打包工具配置

一句話:

"type": "module" 不是一個“順手就能加”的裝飾字段, 而是一條語法立場的選擇題。

5. bin:把腳本變成真正的命令行工具

當一個 npm 包希望被這樣使用時:

mardinjs build

就必須在 package.json 里聲明 **"bin"**:

{
  "bin": {
    "mardinjs": "./bin/mardin.js"
  }
}

比如有些庫(例如性能優化相關的工具包 mardinjs), 就是通過這種方式提供命令行能力。

常見翻車點:

  • 指向的 ./bin/mardin.js 根本不存在
  • 文件存在,卻沒有可執行權限
  • 或者忘記在文件頭部聲明解釋器

結果就是用戶一安裝,立刻看到:

Error: cannot find module './bin/mardin.js'

Fix:

確保路徑正確,文件真實存在。

文件頂部加上 shebang:

#!/usr/bin/env node

賦予可執行權限:

chmod +x ./bin/mardin.js

只要這三步走對,包就能像一條真正的 CLI 命令一樣被調用。

6. engines:被 Node 版本“反向教育”的那一刻

有些最糟糕的部署事故,表面看起來是“語法突然報錯”, 實際上是——線上 Node 版本根本帶不動本地寫好的代碼。

典型場景:

  • 本地用 Node 18 寫了各種:

可選鏈 ?.

空值合并 ??

  • 結果線上服務器還是 Node 14
  • 一上線,就是大面積語法崩潰

這時候,"engines" 字段就該出場了:

{
  "engines": {
    "node": ">=18.0.0",
    "npm": ">=8.0.0"
  }
}

它的作用是:

  • 告訴安裝者:這個項目最低需要什么版本的 Node / npm
  • 某些平臺(如某些云服務、包管理工具)會在不滿足時直接報警甚至拒絕構建

還可以配合 "engineStrict": true 做更強硬的限制。

對團隊協作和長期維護來說,這是一個非常值的“提前聲明”。

7. files:決定發到 npm 上的,究竟有哪些東西

當一個包要發布到 npm 時,**"files" 字段負責決定:**

哪些目錄、哪些文件,會真正被上傳。

例如:

{
  "files": ["dist", "bin"]
}

很常見的一次翻車,是:

  • 忘了把 dist(打包后的產物)寫進來
  • 發布之后,用戶安裝到本地
  • 結果下載到的是一個“只有源碼、沒有構建產物”的空殼

Fix:

  • 確認構建輸出目錄(如 distbuild)確實包含在 "files" 里
  • 或者通過 .npmignore 來排除不想發出去的文件

一句話:

“源碼寫得多好不重要, 用戶真正拿到的,是 files 指定的那一份。”

8. readme & 元數據:不僅是門面,也是“可維護性”的一部分

npmjs.com 上很多項目的詳情頁,看上去一片空白:

  • 沒有 readme
  • description 是一句敷衍
  • author 留著默認或亂填

一個最基本的元數據結構,大致應該是這樣:

{
  "name": "my-app",
  "version": "1.0.0",
  "description": "A simple React + Node.js project",
  "author": "Your Name"
}

這些字段的意義遠不止“好看”:

  • 方便別人搜索和評估這個項目
  • 方便團隊內部追溯“是誰寫的、做什么用的”
  • 對開源項目來說,也是“對用戶負責”的基本禮節

在很多正式面試里, 面試官一看到 package.json 連最基本的信息都不完整, 印象分就已經先掉一截。

9. 當依賴樹“腐爛”的時候,最簡單那招反而最好用

有時候,項目會突然陷入一種“到處都是奇怪錯誤”的狀態:

  • 明明昨天還能跑
  • 今天各種莫名其妙的報錯
  • 重啟、重裝、重試,依然一團亂麻

多半是因為:依賴樹已經腐爛了。

比如:

  • 某個庫偷偷發了一個問題版本
  • 鎖文件和 node_modules 不一致
  • 反復安裝疊出了一堆幽靈依賴

而很多團隊最后的解決方案,往往出奇樸素:

rm -rf node_modules
rm package-lock.json
npm install

然后,一切恢復正常。

這一刻,很多人會意識到:

依賴不是一次裝完就能永遠放心,依賴衛生(dependency hygiene)是必須長期維護的一項工程。

結語:package.json 是項目的“心跳圖”

package.json 從來不是一個“隨便寫寫的配置文件”, 而是一個項目的生命體征

  • 依賴關系
  • 腳本命令
  • 運行環境
  • 發布內容

每一個字段, 都在悄悄決定:

這個項目是能在面試官的電腦上“一鍵跑起”, 還是在 CI、生產、用戶設備上,一次次翻車。

忽視它,它會用最殘忍的方式回擊—— 從 npm start 的第一個報錯開始。

理解它,項目的穩定性、可維護性和“面試可通過程度”, 都會肉眼可見地提高一大截。

下一步,真正麻煩的部分還在后面——

  • 版本不匹配
  • peerDependencies 報錯
  • 經典的 “dependency hell”

這些東西,完全可以在項目剛起步的時候就被處理掉, 而不是等到 React 或 Node.js 項目已經跑到一半,才被迫返工。

想避免那些“明明代碼沒問題,卻被依賴拖下水”的場景, 從看懂、寫好、維護好一個 package.json 開始,就已經贏了半步。

責任編輯:武曉燕 來源: 大遷世界
相關推薦

2025-07-07 00:00:00

MCPA2AAPI

2025-10-27 01:33:00

ReactDOMFiber

2022-07-25 10:24:00

開源開發者工作機會EDB

2025-06-23 00:04:00

2015-08-27 09:43:00

開發者移動應用

2022-03-04 09:31:56

Java開發人員Java 17

2023-07-12 07:56:13

CSS規則元素

2012-06-17 13:14:29

創業創業公司信息圖

2017-03-24 09:37:45

前端開發者JavaScript面試題

2020-02-20 10:50:30

多數人不會真正成功

2022-06-10 09:00:53

前端項目個JSON

2021-08-02 15:23:16

Windows 10Windows微軟

2022-02-09 07:40:42

JavaScript前端面試題

2022-07-27 08:27:34

Call前端

2009-07-14 15:39:34

Swing大多數控件

2021-08-09 15:06:10

數字貨幣區塊鏈貨幣

2021-02-25 23:31:50

加密貨幣比特幣貨幣

2023-01-31 10:22:00

HiveMapReduce文件合并

2024-08-22 18:53:51

2011-05-26 10:50:31

點贊
收藏

51CTO技術棧公眾號

精品人妻在线视频| 人妻av中文系列| 国内精品久久久久久久久久久| 欧美激情无毛| 国产视频丨精品|在线观看| 992kp快乐看片永久免费网址| 黄色免费网站在线观看| av网站免费线看精品| 国产精品99久久久久久久久久久久 | 精品一区二区三区免费播放| 欧美日本高清视频| 四虎影成人精品a片| 9999精品免费视频| 日韩欧亚中文在线| 久久久久久久香蕉| 国产女人在线观看| 成人黄色在线看| 成人国产精品一区二区| 欧美一区二区三区四| 99免费精品| 亚洲免费视频观看| 少妇欧美激情一区二区三区| 丝袜美腿一区| 亚州成人在线电影| 强伦女教师2:伦理在线观看| 裸体xxxx视频在线| 粉嫩aⅴ一区二区三区四区五区| 国产成人精品在线播放| 国产亚洲成人精品| 亚洲国产一区二区在线观看| 亚洲欧美一区二区激情| 人妻 日韩 欧美 综合 制服| 9999精品| 欧美高清视频不卡网| 日韩av播放器| av在线不卡免费| 亚洲女同ⅹxx女同tv| 视频一区视频二区视频| 桃花色综合影院| 不卡的看片网站| 99re视频在线观看| 国产强伦人妻毛片| 精品影视av免费| 国产精品免费看久久久香蕉| 免费看毛片网站| 在线亚洲精品| 97久久精品国产| 五月天婷婷丁香| 欧美日韩a区| 久久国产天堂福利天堂| 顶级黑人搡bbw搡bbbb搡| 精品国内自产拍在线观看视频| 亚洲精品第一页| 波多野结衣加勒比| 精品日产乱码久久久久久仙踪林| 精品日韩在线观看| 中文字幕亚洲日本| 亚洲视频国产| 精品日韩在线一区| 精品人妻在线视频| 亚洲国产最新| 亚洲一区二区福利| 国产福利在线导航| 欧美激情成人| 久久国产精品首页| 国产亚洲欧美精品久久久www| 欧美另类综合| 91国产精品91| 久久久精品毛片| 青青青伊人色综合久久| 91精品美女在线| 国产色在线视频| 国产乱国产乱300精品| 亚洲一区二区三区毛片| www精品国产| av欧美精品.com| 色涩成人影视在线播放| 免费网站黄在线观看| 亚洲日本欧美天堂| 久操网在线观看| 免费观看一级欧美片| 91久久线看在观草草青青| 成人免费在线观看视频网站| 国产精久久一区二区| 精品va天堂亚洲国产| 精品人妻一区二区三区香蕉 | 99蜜月精品久久91| 在线成人免费视频| 艳妇乳肉豪妇荡乳xxx| 国产一区二区三区四区| 久久精品国产69国产精品亚洲| 青青草国产在线观看| 亚洲一区网站| 91美女高潮出水| 神马午夜在线观看| 国产精品福利影院| 国产毛片视频网站| 日本成人一区二区| 精品夜色国产国偷在线| 日本一级特级毛片视频| 亚洲伦伦在线| 91精品免费看| 可以免费看污视频的网站在线| 亚洲婷婷在线视频| 国产精品无码专区av在线播放| www.欧美视频| 亚洲人午夜色婷婷| 久久久精品人妻一区二区三区四| 久久精品电影| 国产精品毛片va一区二区三区| 成人高清免费观看mv| 亚洲福利一二三区| 免费网站在线观看黄| 亚洲黄色录像| 欧美激情在线观看视频| 亚洲最大成人av| 国产亚洲一二三区| 九色自拍视频在线观看| 国产成人视屏| 日日摸夜夜添一区| aaa在线视频| av一区二区三区黑人| 欧美美女黄色网| 日本一区免费网站| 亚洲欧美另类人妖| 日韩 欧美 精品| 国产精品一区一区| 亚洲欧洲日韩综合二区| 伊人久久综合一区二区| 精品国产免费一区二区三区香蕉| 手机免费观看av| 久久看片网站| 激情视频一区二区| 波多野结衣在线播放| 欧美一二三四在线| 成年人视频软件| 日韩av网站免费在线| 蜜桃91精品入口| sm久久捆绑调教精品一区| 8v天堂国产在线一区二区| 丁香花五月婷婷| 久久天堂成人| 日本成人黄色| 成人性教育av免费网址| 日韩精品在线视频观看| 日韩三级一区二区三区| 成人激情动漫在线观看| 日本阿v视频在线观看| 视频一区中文字幕精品| 操91在线视频| 亚洲av无码专区在线| 亚洲精品国产一区二区精华液| 五月六月丁香婷婷| 一本一本久久a久久综合精品| 91久久精品国产| 污污网站在线观看| 精品免费日韩av| 成年人午夜视频| 99精品欧美一区| 国产精品欧美激情在线观看| 精品久久中文| 亚洲伊人久久大香线蕉av| 国内精品久久久久久野外| 91精品国产高清一区二区三区蜜臀| 久久久久久视频| 成人高清av在线| 久久国产成人精品国产成人亚洲| 午夜欧洲一区| 国产精品啪视频| bt在线麻豆视频| 精品国产一区二区三区忘忧草| 欧美成人精品欧美一级乱黄| 久久夜色精品一区| 91在线视频观看免费| 日韩视频在线观看| 99r国产精品视频| 亚洲精品mv| 北条麻妃一区二区三区中文字幕| aa视频在线免费观看| 亚洲.国产.中文慕字在线| 一级片手机在线观看| 精品在线视频一区| 免费毛片网站在线观看| 精品国产不卡| 91文字幕巨乱亚洲香蕉| 国产污视频在线播放| 日韩成人中文字幕| 在线免费a视频| 亚瑟在线精品视频| 国产视频不卡在线| 国产成人在线观看免费网站| 99精品免费在线观看| 国产精品毛片一区二区在线看| 国产精品久久久久久久久久直播 | 国产尤物99| yw.尤物在线精品视频| 欧美久久精品午夜青青大伊人| 性感美女福利视频| 欧美日韩国产综合视频在线观看| 久一视频在线观看| 中文字幕av在线一区二区三区| 美女被爆操网站| 日韩va亚洲va欧美va久久| 国产在线xxxx| 91视频精品| 蜜桃免费一区二区三区| www.成人| 国产精品专区一| 欧美男人天堂| 久精品免费视频| 三级外国片在线观看视频| 亚洲国产美女精品久久久久∴| 一级黄色小视频| 狠狠躁夜夜躁久久躁别揉| 侵犯稚嫩小箩莉h文系列小说| 久久久99精品免费观看| 日本不卡视频一区| 国产最新精品精品你懂的| 成人在线观看黄| 一本一道久久综合狠狠老精东影业| 中文字幕av日韩精品| 亚洲欧美成人vr| 国产视频不卡| 91精品入口| 亚洲一区二区免费在线| 免费在线成人激情电影| 日本精品一区二区三区在线播放视频| 日本一本在线免费福利| 久久精品国产2020观看福利| 成年人在线观看| 亚洲欧洲日本专区| 天天av综合网| 亚洲国内高清视频| 国内爆初菊对白视频| 欧美一区二区精品在线| 91麻豆一区二区| 欧美人与性动xxxx| 亚洲一卡二卡在线观看| 在线观看国产91| 波多野结衣黄色| 欧美性videosxxxxx| 国产亚洲欧美日韩高清| 色香蕉成人二区免费| youjizz在线视频| 欧美性生活大片免费观看网址| 日本在线小视频| 精品久久香蕉国产线看观看亚洲| www.av视频在线观看| 亚洲妇熟xx妇色黄| 成年免费在线观看| 欧美性色19p| 国产美女www爽爽爽| 欧美主播一区二区三区| 伊人22222| 69成人精品免费视频| hs视频在线观看| 亚洲精品在线电影| 四季av日韩精品一区| 亚洲激情视频在线播放| 香蕉国产在线视频| 亚洲欧美综合v| 成年人视频在线观看免费| 日韩亚洲欧美成人| 91网在线看| 韩国一区二区电影| 视频二区不卡| 91天堂在线观看| 北条麻妃一区二区三区在线| 久久影视中文粉嫩av| 狠狠做深爱婷婷综合一区| 亚洲午夜精品国产| 欧美久色视频| 欧在线一二三四区| 激情欧美日韩一区二区| 国产精久久久久| 国产亚洲女人久久久久毛片| 日本爱爱小视频| 香蕉加勒比综合久久| 色老头一区二区| 欧美xxxxxxxx| 国产在线超碰| 欧美另类交人妖| 欧美精品日日操| 91黄在线观看| 欧美精选一区二区三区| 超碰超碰超碰超碰超碰| 国产视频一区在线观看一区免费| www.99av.com| 成人午夜电影久久影院| 人妻一区二区视频| 亚洲欧美视频在线观看视频| 国产精品免费av一区二区| 欧美性视频一区二区三区| 亚洲成人第一区| 色先锋资源久久综合5566| 国产盗摄一区二区| 国产精品揄拍一区二区| 国产乱人伦丫前精品视频| 亚洲精品国产系列| 尹人成人综合网| 久久久九九九热| 国产亚洲午夜高清国产拍精品| 国产亚洲精品成人| 欧美色图免费看| 五月天激情婷婷| 欧美成人一区二区三区电影| 桃花岛成人影院| 国产精品亚洲一区| 99视频精品全部免费在线视频| 乱妇乱女熟妇熟女网站| 国产美女视频一区| 一区二区三区在线观看免费视频| 亚洲福利视频一区二区| 国产精品视频a| 在线不卡国产精品| 欧美91看片特黄aaaa| 久久99国产精品| 欧美日韩亚洲三区| 亚洲一区二区福利视频| 国产欧美综合色| 四虎成人永久免费视频| 精品国产乱码久久久久久久久| 蜜桃视频网站在线| 国产精品久久久av| 免费观看久久av| 欧美精品99久久| 成人美女在线视频| 欧美日韩精品亚洲精品| 91精品午夜视频| 免费观看在线黄色网| 国产精品福利无圣光在线一区| 欧美调教在线| 福利视频一区二区三区四区| 国产乱子伦视频一区二区三区 | 亚洲国产美女搞黄色| 国产毛片毛片毛片毛片毛片| 色婷婷**av毛片一区| 成人av色网站| 亚洲成色最大综合在线| 日韩精品亚洲一区| 99精品欧美一区二区| 色综合激情久久| 国产视频第一页在线观看| 奇米成人av国产一区二区三区| 丝袜久久网站| 欧美少妇性生活视频| 国产欧美日韩三级| 精品国产www| 综合久久五月天| 欧美一区二区三区婷婷| 一本色道久久综合亚洲二区三区| 久久www免费人成看片高清| 992在线观看| 91精品在线观看入口| 成人三级网址| 99热在线播放| 99精品国产一区二区青青牛奶| 亚洲一区二区三区四区五区六区| 欧美日韩国产在线播放| 欧洲免费在线视频| 国产精品夫妻激情| 久久激情电影| 人妻精品久久久久中文字幕69| 亚洲一区在线看| 青青视频在线观| 国产精品日韩专区| 中文字幕一区二区三区久久网站| 佐佐木明希电影| 一本到不卡免费一区二区| 成年女人的天堂在线| 91在线网站视频| 国产日韩高清一区二区三区在线| 成人影视免费观看| 欧美视频在线不卡| 最新国产在线拍揄自揄视频| 国产精选一区二区| 日韩精品一级中文字幕精品视频免费观看 | 亚洲天堂网在线观看视频| 久久这里有精品视频| 国产精品极品在线观看| 毛片av免费在线观看| 日韩美女视频19| 午夜影院免费体验区| 国产一区二区在线免费| 黄色工厂这里只有精品| 97在线观看免费视频| 日韩欧美一区二区免费| 欧美羞羞视频| 色妞色视频一区二区三区四区| 国产强被迫伦姧在线观看无码| 欧美二区在线播放| 欧美女优在线视频| 福利视频999| 高潮白浆女日韩av免费看| 777电影在线观看| 国产视色精品亚洲一区二区| 美女网站在线免费欧美精品| 日本亚洲欧美在线| 日韩在线小视频| 五月国产精品|