查看项目中无引用到的文件、函数

unimported 查看没有引用的文件

  1. 全局安装 unimported

    npm install -g unimported

  2. 在 package.json 的 scripts 增加

json 复制代码
"scripts": {   
  "analyze:deadcode": "unimported && webpack --profile --json > stats.json" 
} 
  1. 增加文件 .unimportedrc.json
json 复制代码
{
    "entry": [
      "src/app.{js,ts,jsx,tsx}",       
      "src/app.config.{js,ts}",        
      "src/pages/**/*.{js,ts,jsx,tsx}"
    ],
    "ignore": [
      "**/node_modules/**",
      "**/dist/**",
      "**/*.d.ts",
      "**/*.test.{js,ts}",
      "**/*.spec.{js,ts}",
      "**/__mocks__/**",
      "project.config.json",
      "config/**/*.js"                 
    ],
    "ignoreUnused": [
      "src/types/**/*.d.ts",           
      "src/assets/**/*",               
      "src/styles/**/*.{css,scss,less}" 
    ]
  }
  1. 然后运行
arduino 复制代码
npm run analyze:deadcode

运行后输出以下内容,列出未引用的文件

注意 有些小程序页面 A 也会有 /component 的组件,只给页面A用, 但是 "src/pages/**/*.{js,ts,jsx,tsx}" 会涵盖掉,不会把A的无用组件列出来, 这种情况下,小程序最好每个页面的路径都列出来,例如以下,这样可以更加精确的定位到每个页面ABCD里面的component是否真正有被使用

json 复制代码
{
    "entry": [
      "src/app.{js,ts,jsx,tsx}",       
      "src/app.config.{js,ts}",        
      "src/pages/index/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/home/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/category/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/cart/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/mine/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/product/detail/index.{js,ts,jsx,tsx,config.ts}",
      "src/pages/product/content-hub/index.{js,ts,jsx,tsx,config.ts}",
    ],
    "ignore": [ ],
    "ignoreUnused": [ ]
  }

使用Webpack插件 webpack-deadcode-plugin 查看未使用的函数和变量

  1. 安装 webpack-deadcode-plugin
css 复制代码
npm install webpack-deadcode-plugin --save-dev
  1. 在webpack配置中添加:
php 复制代码
const DeadCodePlugin = require('webpack-deadcode-plugin');

// 增强配置可检测具体方法
chain.plugin('deadcode')
  .use(DeadCodePlugin, [{
    detectUnusedExport: true,    // 检测未使用的导出
    detectUnusedClass: true,     // 检测未使用的类
    detectUnusedFunction: true,  // 检测未使用的函数
    detectUnusedVariable: true,  // 检测未使用的变量
    log: 'all'                   // 显示所有未使用项
  }]);
  1. 运行构建后会生成未使用文件的报告

通过这些方式可以 了解到 哪些文件、函数、变量没有使用到

如果要删除

  1. 一定要确认、确认、确认、多次确认 清楚再删
  2. 小规模的删,不要一次性删太多东西
  3. 删除之后,对于相关的流程做好自测,也要跟 QA 和 产品说明清楚,可能要做大版本的回测
  4. 对于已经上线的项目,不建议再做这样的操作,如果需要做也必须【提前】跟 PM、QA 商量一下是否有足够的时间安排来做代码优化和流程测试,避免出现生产事故
相关推荐
于慨20 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz20 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶20 小时前
前端交互规范(Web 端)
前端
CHU72903520 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing20 小时前
Page-agent MCP结构
前端·人工智能
王霸天20 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航20 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界20 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc20 小时前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说20 小时前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js