package.json文件详解
package.json是什么?
Node.js项目遵循模块化的架构,当我们创建了一个Node.js项目,意味着创建了一个模块,这个模块的描述文件,被称为package.json。
使用的是Facebook推出的creat-react-app (antd官网有文档)
react-app-rewired2.x以后,不再支持injectBabelPlugin的方式,需要安装customize-cra。
1.首先 我们按照react-app-rewired
yarn add react-app-rewired
2.修改package.json中的文件
/* package.json */ "scripts": { - "start": "react-scripts start", + "start": "react-app-rewired start", - "build": "react-scripts build", + "build": "react-app-rewired build", - "test": "react-scripts test", + "test": "react-app-rewired test", }
接着 安装 customize-cra
yarn add customize-cra
然后在根目录下添加config-overrides.js文件。
module.exports = function override(config, env) { // 关于webpack的相关配置 return config; };
基本的操作就是这样。下面我们再来说具体到我们的项目中,需要做的一些配置。
1、react项目中我们最常用的组件库antd,我们需要配置按需加载。
使用babel-plugin-import,它是一个用于按需加载组件代码和样式的 babel 插件。
安装
yarn add babel-plugin-import
接着配置webpack
/* config-overrides.js */ + const { override, fixBabelImports } = require('customize-cra'); - module.exports = function override(config, env) { - return config; - }; + module.exports = override( + fixBabelImports('import', { + libraryName: 'antd', + libraryDirectory: 'es', + style: 'css', + }), + );
这样我们在组件中就可以按需引入组件库中所需要的组件了。
2、自定义主题
按照配置主题的要求,自定义主题需要用到 less 变量覆盖功能。
安装less和less-loader
yarn add less less-loader
配置webpack
/* config-overrides.js */ - const { override, fixBabelImports } = require('customize-cra'); + const { override, fixBabelImports, addLessLoader } = require('customize-cra'); module.exports = override( fixBabelImports('import', { libraryName: 'antd', libraryDirectory: 'es', - style: 'css', + style: true, }), + addLessLoader({ + javascriptEnabled: true, + modifyVars: { '@primary-color': '#1DA57A' }, + }), );
这里利用了less-loader的modifyVars来进行主题配置。当然这里的modifyVars的值也可以是一个theme文件。
3、打包后我们会发现静态文件夹中会有很多的css和js的map文件,那么我们该怎么关闭sourcemap呢?
/* config-overrides.js */ const { override, fixBabelImports, addLessLoader } = require("customize-cra"); + process.env.GENERATE_SOURCEMAP = "false"; module.exports = override( fixBabelImports("import", { libraryName: 'antd', libraryDirectory: "es", style: true, }), addLessLoader({ javascriptEnabled: true, modifyVars: { '@primary-color': '#1DA57A' }, }) );
ok,再次执行npm run build便不会产生map文件了。
还看到一种解决的方式如下
const rewiredMap = () => config => { config.devtool = config.mode === 'development' ? 'cheap-module-source-map' : false; return config; }; module.exports = override( // 关闭mapSource rewiredMap() );
参考地址:https://segmentfault.com/q/10100000181231940
4、支持装饰器
const { override, addDecoratorsLegacy } = require("customize-cra"); module.exports = override( addDecoratorsLegacy() );
cross-env脚本 -- 运行跨平台设置和使用环境变量的脚本
为什么使用?
简单概括:windows不支持NODE_ENV=development的设置方式
windows不支持NODE_ENV=development的设置方式。
这个迷你的包(cross-env)能够提供一个设置环境变量的scripts,让你能够以unix方式设置环境变量,然后在windows上也能兼容运行。
- ~1.2.3 => <1.3.0
- ^1.2.3 => <2.0.0
- * 无论如何更新到最新版本
安装依赖
千万不要手动添加package 然后npm install,一定要通过工具安装 npm i worker-loader@3.0.8 -S, 防止出问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现