前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Webpack提示“the request of a dependency is an expression”解决办法

Webpack提示“the request of a dependency is an expression”解决办法

原创
作者头像
用户8703799
发布2023-09-27 07:35:12
1.9K0
发布2023-09-27 07:35:12
举报
文章被收录于专栏:javascript技术

Webpack编译出错“Critical dependency: the request of a dependency is an expression”解决办法

当使用webpack进行打包时,如果遇到如下的require语法,

代码语言:javascript
复制
var mx = require("hpargxm".split("").reverse().join(""));

编译将出错,会提示“Critical dependency: the request of a dependency is an expression”

这种require语法是正确的,但webpack不能处理require中的表达式,只能识别字符串,如:

代码语言:javascript
复制
var mx = require('mxgraph');

这是因为,webpack要判断require引用的文件,并读取和合并文件内容。由于webpack无法执行js代码,所以,当require的内容是表达式时,webpack无法正确获取文件信息。

这属于webpack无奈的bug,解决办法是需要webpack具备执行js代码能力,比如可以内置一个javascript小引擎,以便解析表达式内容。

在实际的编程中,如果遇到这种问题,只需修改require中的表达式为字符串即可。

另外,当进行JS代码混淆时,也常会对require中的字符串内容进行加密,也会引发webpack的这个bug,解决办法是:规避指定的字符,比如使用JShaman进行JS代码混淆时,可以配置“保留字”,对指定的字符串不进行加密。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档