vue项目全局挂载函数 — webpack.ProvidePlugin

ProvidePlugin:(官方文档解释)

自动加载模块,而不必在任何地方 importrequire它们。

理解:在项目中,存在业务逻辑相同的功能,为了减少代码的书写,我们一般会选择抽离出复用的代码写在一个**.js文件中,然后将其向外暴露出去;使用的时候通过import**导入。

假如项目中有 50+ 个单文件组件(.vue)且每个组件中都要使用这个模块(.js )中向外暴露的方法,那我们是不是需要 50+ 个import 语句。为了避免这种情况的发生,所以想到把该方法变成全局的。把某个方法变成全局方法有多种方式,此文章仅记录通过webpack.ProvidePlugin进行挂载!!!

先附上官方文档

项目中应用

首先,创建一个js文件 (文件在项目中的路径 src/utils/index.js)并把需要向外暴露的方法、变量等export出去。

javascript 复制代码
//src/utils/index.js
import axios from "axios";
function add() {
  console.log("add");
}
function add2() {
  console.log("add2");
}
export { add, add2, axios };

接着,开始配置vue.config.js文件 。

javascript 复制代码
const { defineConfig } = require("@vue/cli-service");
const webpack = require("webpack");

const path = require("path");
module.exports = defineConfig({
  productionSourceMap: false,
  lintOnSave: false,
  configureWebpack: {
    plugins: [
       //挂载全局方法
      new webpack.ProvidePlugin({
        FF: [path.resolve(__dirname, "src/utils/index")],
      }),
    ],
  },
});

最后,在该使用它的地方开始使用。(我是在About.vue中进行使用的,只进行了打印)

javascript 复制代码
<template>
  <div class="about">
    <h1>This is an about page</h1>
  </div>
</template>
<script setup>
import { onMounted } from "vue";
onMounted(() => {
  console.log(FF);
});
</script>

控制台打印结果:【可以看出,FF 变量存储的就是index.js 模块中向外暴露的东西,如果我们想使用add方法,是不是可以直接FF.add()

那稍微的改动一下vue.config.js文件,index.js文件和About.vue文件中内容都不变!!!

再来看下控制台输出内容:

修改 vue.config.js 文件内容和index.js文件中的内容再看控制台打印内容

控制台结果:

只修改 index.js文件,保持vue.config.js文件不变

输出结果:

OK!到这就结束了,可以自己手动测试一下。谨记,每次修改完 vue.config.js 文件要重启项目!!!

相关推荐
王解43 分钟前
webpack loader全解析,从入门到精通(10)
前端·webpack·node.js
我不当帕鲁谁当帕鲁1 小时前
arcgis for js实现FeatureLayer图层弹窗展示所有field字段
前端·javascript·arcgis
那一抹阳光多灿烂1 小时前
工程化实战内功修炼测试题
前端·javascript
放逐者-保持本心,方可放逐2 小时前
微信小程序=》基础=》常见问题=》性能总结
前端·微信小程序·小程序·前端框架
毋若成4 小时前
前端三大组件之CSS,三大选择器,游戏网页仿写
前端·css
红中马喽4 小时前
JS学习日记(webAPI—DOM)
开发语言·前端·javascript·笔记·vscode·学习
Black蜡笔小新5 小时前
网页直播/点播播放器EasyPlayer.js播放器OffscreenCanvas这个特性是否需要特殊的环境和硬件支持
前端·javascript·html
秦jh_6 小时前
【Linux】多线程(概念,控制)
linux·运维·前端
蜗牛快跑2136 小时前
面向对象编程 vs 函数式编程
前端·函数式编程·面向对象编程
Dread_lxy6 小时前
vue 依赖注入(Provide、Inject )和混入(mixins)
前端·javascript·vue.js