草庐IT

mocha-webpack

全部标签

javascript - 为什么 React 应用程序的生产构建(使用 Webpack 和 Babel)使用错误的开发环境和 HMR,这会导致错误?

我正在尝试创建我的React项目的生产版本,但它选择了错误的配置。在开发版本中,我使用的是HMR(热模块更换)。这是在.babelrc中配置的,位于env>development>plugins下。添加额外节点env>production时,它似乎被忽略了。它仍然使用带有HMR的开发配置,这会导致错误:UncaughtError:locals[0]doesnotappeartobeamoduleobjectwithHotModulereplacementAPIenabled.Youshoulddisablereact-transform-hmrinproductionbyusingen

javascript - Mocha 的 before() 函数的目的是什么?

Mocha有几个“钩子(Hook)”可以在独立于测试用例本身的测试中运行辅助功能(清除数据库、创建模拟文件等)。但是,在before()的情况下(不是beforeEach(),我得到的那个),它看起来很多余。before()在当前套件中的所有测试之前运行逻辑一次,那么为什么我需要将它包装在一个函数中?以下两者之间没有明显的区别:describe('Something',function(){before(doSomePreTestLogic);//Testsahoy});和describe('Something',function(){doSomePreTestLogic();//Te

javascript - 扩展 HTMLElement : Constructor fails when webpack was used

我将以下TypeScript程序转换为ES5:文件1:classBaseElementextendsHTMLElement{constructor(){super();}}文件2:import{BaseElement}from'./BaseElement';classMyElementextendsBaseElement{constructor(){super();}}varel=newMyElement();将所有内容手动放入文件中,代码运行良好并在浏览器中执行,HTMLElement的构建没有问题。但是,一旦我通过webpack打包它,我就会收到以下错误消息:UncaughtTyp

javascript - 如何将库与 webpack 捆绑在一起?

我想创建一个前端库。因此我想使用webpack。我特别喜欢css和图像加载器。但是,如果我使用webpack,我只能需要非JS文件。因为我正在build一个图书馆,所以我不能保证图书馆的用户也会这样做。有没有办法将所有内容捆绑到一个UMD模块中进行发布?我尝试使用多个入口点,但是我不能要求模块。 最佳答案 您可以找到在Webpack2.0中创建库的好指南documentationsite.这就是我在webpack.config.js中使用ver2语法的原因。这是一个Githubrepo带有示例库。它将所有来自src/的文件(js、p

javascript - Webpack 2 - 代码拆分顶级依赖

最终编辑tl;dr的结论是这是不可能的。虽然下面的最佳答案确实提供了一些很好的信息。考虑下面的代码,来自contacts.js。这是一个动态加载的模块,通过代码中其他地方的System.import按需加载。如果SharedUtil1也在其他模块中使用,它们也是通过System.import动态加载的,我将如何拥有SharedUtility1从所有这些模块中排除,并且仅在第一次需要时按需加载?SharedUtil1的顶层System.import将不起作用,因为我的导出依赖于它:导出只能放在模块的顶层代码,不在任何类型的回调中。Webpack可以吗?我使用的是2.0.7测试版。impo

javascript - Webpack:导出到窗口中的现有模块

我的目标是使用Webpack将一个独立的组件导出到一个假定的全局对象中。index.htmlvarMyApp=window.MyApp||{};MyApp.something=MyApp.something||{};////othermodules/componentsloadedhere...//MyApp.something.myIsolatedModule.run();在上面的例子中,我假设有一个全局对象/模块,它有一个属性something,它将有其他模块附加到它。所以我想将我的隔离模块附加到全局MyApp.something对象,而不破坏MyApp或MyApp.somethi

javascript - 如何将 Webpack 与 Angular + templateCache 一起使用?

我正在学习Webpack。我用Angular制作了一个应用程序,我使用templateCache在一个js文件中生成我所有的htmlView,而不是应用程序中的要求。它很酷。但是Webpack的工作:entry:{app:["bootstrap-webpack!./bootstrap.config.js",'./app/app.js'],vendor:['angular','bootstrap','angular-ui-router','oclazyload']},output:{path:path.join(__dirname,"dist"),filename:'/bundle.js

javascript - 动态加载外部 webpack 捆绑的 ngModule 作为路由处理程序

我们想将我们的大型前端项目分成多个单独部署的项目,这样更容易使用。我正在尝试包含一个捆绑的ngModule来处理来自另一个应用程序的路由。这些应用程序必须不知道彼此的配置。这些包将通过全局变量共享一些大型依赖项(如Angular)。我们不需要跨包摇晃,我们可能只需要接受一些重复的依赖项。根路由器提示Error:NoNgModulemetadatafoundfor'TestsetModule'.这让我相信子模块没有在加载时进行Angular编译,或者由于某种原因没有注册它的模块。我认为可能需要手动编译模块,但我不确定如何使用这个https://angular.io/api/core/Co

javascript - (Webpack) 如何分块动态模块依赖

我刚刚意识到,如果您使用require.ensure()动态加载模块,webpack将不会分析和分块依赖关系。这在某种程度上是有道理的,有人可能会争辩说,webpack不知道这些模块是否曾经被传输过,但我们能强制webpack完成这项工作吗?例子是:app.js:require.ensure(['module1.js'],(require)=>{//atsomepointrequire('module1.js');},'Module1');require.ensure(['module2.js'],(require)=>{//atsomepointrequire('module2.js

javascript - 从 Webpack 1.x 迁移到 2.x

在Webpack1.x中,我曾经定期执行以下操作:require.ensure(['./mod2.js'],(require)=>{setTimeout(()=>{//somelaterpointintime,mostlikelythroughanykindofeventvardata=require('./mod2.js');//actualevaluatingthecode},1100);},'myModule2');通过这种技术,我们能够通过网络传输webpack-bundle,但会在稍后的某个时间点评估该包的实际内容(JavaScript代码)。此外,使用require.ens