Encore Global 不适用于旧版应用程序

问题描述

大约 2 个小时,我现在尝试在 app.js 中使用带有全局变量的 encore 之外的 jquery 等库,如下所示:

const $ = require('jquery');
global.$ = global.jQuery = $;

此处解释了此方法:jQuery Plugins and Legacy Applications (Symfony Docs)

但不幸的是,我无法在模板内的脚本标记中访问 $jQuery

我的 webpack-configuration 不包含 autoProvidejQuery() 或其他人已经建议注释掉的其他方法,以使 jQuery 可以在外部访问。

我的 webpack 配置:

Encore
    .setOutputPath('public/build/')
    .setPublicPath('/build')
    .addEntry('app','./assets/app.js')
    .splitEntryChunks()
    .enableSingleRuntimeChunk()
    .cleanupOutputBeforeBuild()
    .enableBuildNotifications()
    .enableSourceMaps(!Encore.isProduction())
    .enableVersioning(Encore.isProduction())
    .configureBabel((config) => {
        config.plugins.push('@babel/plugin-proposal-class-properties');
    })
    .configureBabelPresetEnv((config) => {
        config.useBuiltIns = 'usage';
        config.corejs = 3;
    })
    .enableSassLoader();

我在正文末尾使用jQuery的方式(示例):

<script>
    $('#nav').html('Hello World');
</script>

产生的异常:

未捕获的引用错误:$ 未定义

总而言之,我在 stackoverflow 和其他平台上寻找解决方案已经有一段时间了,但没有解决方案适合我,所以您可能有我的问题的解决方案......

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...