我的 webpack/babel 配置有问题。我已经将我的组件存储库(里面没有 webpack 配置的 es6 模块)安装为 node_module。在这种情况下它不起作用 - 我收到“意外的 token 导入”错误(babel 不转换 es6 代码)
但是,如果我将外部文件夹链接到 node_modules(npm 链接 ./../../component-repository),那么它可以正常工作,没有任何错误。 我花了很多时间,仍然无法解决这个问题。
主要问题是如何在各个项目之间共享 React 组件。我的想法是将它们添加为依赖项。
编辑:如何为项目设置 webpack&babel 以从 node_modules 文件夹编译 ES6 模块?具有指向兄弟文件夹的 npm 链接的解决方案不适用于生产环境。
edit2:我将 es6 代码保留在模块中的原因是,在本地环境中,我想 npm 链接同级文件夹和组件(我可以编辑组件,然后将更改提交到它们的存储库)。我在 3 个项目之间共享组件。但是在生产中我想从 git 存储库自动安装它们作为依赖
本地环境的结构:
生产结构:
最佳答案
发帖晚了,但我今天遇到了这种情况。 对我来说,问题是由 babel require hook 引起的:
https://babeljs.io/docs/usage/require/
NOTE: By default all requires to node_modules will be ignored.
基本上,babel 没有被用于任何指向 node_modules 的需求。这就是代码适用于 npm 链接模块的原因,我猜 babel 会跳过忽略,因为路径不包含 node_modules。
我能够通过更改 require 钩子(Hook)中的忽略逻辑来解决这个问题,如下所示:
require('babel-register')({
extensions: [".es6", ".es", ".jsx", ".js"],
ignore: (absPath) => {
if (absPath.lastIndexOf('node_modules') > absPath.indexOf('es6_module')) {
return true;
} else if (absPath.indexOf('es6_module') > -1) {
return false;
} else if (absPath.indexOf('node_modules') > -1) {
return true;
}
return false;
}
});
当然,请确保您的加载程序具有相同的逻辑:
loaders: [
{
test: /\.jsx?$/,
exclude: (absPath) => {
if (absPath.lastIndexOf('node_modules') > absPath.indexOf('es6_module')) {
return true;
} else if (absPath.indexOf('es6_module') > -1) {
return false;
} else if (absPath.indexOf('node_modules') > -1) {
return true;
}
return false;
}
loader: 'babel',
query: {
cacheDirectory: true,
presets: ['es2015', 'react']
}
}
关于javascript - 用于在 node_modules 中编译模块的 Webpack 配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34219546/
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我有一个在Linux服务器上运行的ruby脚本。它不使用rails或任何东西。它基本上是一个命令行ruby脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or
我正在学习如何在我的Ruby代码中使用Module.prepend而不是alias_method_chain,我注意到有些人使用send调用它(example):ActionView::TemplateRenderer.send(:prepend,ActionViewTemplateRendererWithCurrentTemplate)而其他人直接调用它(example):ActionView::TemplateRenderer.prepend(ActionViewTemplateRendererWithCurrentTemplate)而且,虽然我还没有看到任何人使用这种风格,但我从
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c