将 Utils.js 挂载为全局(window.Utils.xx)完整配置方案

将 Utils.js 挂载为全局(window.Utils.xx)完整配置方案分最常用的 3 种场景 (原生 JS / Webpack / Vite)讲清楚,你直接对应自己的项目用就行,所有配置一步到位

核心目标:把 Utils 工具函数挂载到 window 对象 上,全局任何地方直接用 window.Utils.方法名 调用。


一、先写好 Utils.js 本身(通用)

不管什么项目,Utils.js 内部写法固定

javascript 复制代码
// Utils.js
const Utils = {
  // 写你的工具方法
  formatDate: function() {},
  copyText: function() {},
  debounce: function() {},
  // ...更多方法
};

// 关键:挂载到 window 全局
window.Utils = Utils;

// 兼容 CommonJS(可选,让它能被 import/require)
if (typeof module !== 'undefined') {
  module.exports = Utils;
}

二、场景 1:原生 HTML / 无构建工具(最简单)

不需要任何配置!

直接用 <script> 引入 Utils.js 优先加载 即可:

html 复制代码
<!-- 先引入 Utils.js -->
<script src="./Utils.js"></script>

<!-- 后面任何脚本都能直接用 -->
<script>
  // 直接使用
  window.Utils.formatDate();
  Utils.formatDate(); // window 可省略
</script>

✅ 生效条件:Utils.js 必须在使用它的脚本之前加载


三、场景 2:Webpack 项目(Vue2 / React 旧项目)

需要两步配置,让 Webpack 把 Utils 自动挂载到全局。

1. 安装依赖(如果没有)

bash 复制代码
npm install expose-loader --save-dev

2. 配置 webpack.config.js

javascript 复制代码
module.exports = {
  module: {
    rules: [
      {
        test: require.resolve('./src/utils/Utils.js'), // 你的文件路径
        use: [
          {
            loader: 'expose-loader',
            options: {
              exposes: {
                globalName: 'Utils', // 全局变量名
                override: true,
              },
            },
          },
        ],
      },
    ],
  },
};

3. 入口文件 main.js 引入

javascript 复制代码
// main.js
import './utils/Utils.js';

✅ 完成:全局任何文件直接用 window.Utils.xxx


四、场景 3:Vite 项目(Vue3 / React 最新项目)

Vite 更简单,不用装 loader,2 步搞定。

1. 在入口文件 main.js 引入并挂载

javascript 复制代码
// main.js
import Utils from './utils/Utils.js';

// 直接挂载到 window
window.Utils = Utils;

2. 提供类型提示(TS 项目可选)

src/vite-env.d.ts 添加:

typescript 复制代码
declare interface Window {
  Utils: typeof import('./utils/Utils').default;
}

✅ 完成:全局任意地方 window.Utils.方法 直接用


五、验证是否生效

在浏览器控制台 F12 输入:

javascript 复制代码
console.log(window.Utils);

能打印出工具对象 = 配置成功 ✅


最简总结

  1. Utils.js 内部必须写 window.Utils = Utils
  2. 原生项目:直接 script 引入
  3. Webpack:用 expose-loader 配置
  4. Vite :入口文件 window.Utils = Utils 即可
相关推荐
kyriewen39 分钟前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒2 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨4 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE21214 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab16 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆1 天前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen1 天前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
weedsfly1 天前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯1 天前
前端跨域解决方案(学习用)
前端·javascript·面试
铁皮饭盒1 天前
Bun 哪比 Node.js 快?
javascript·后端