- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是这个世界上的新手,所以请耐心等待。
我有一个大库,我正在尝试将其转换为 es6 模块、babel
和 webpack
,以便稍后将其捆绑到多个文件中。
我的库文件夹如下所示
--src
-- core
-- folder1
-- folder2
-- addons
-- addon 1
-- addon 1 files and folders
-- addon 2
-- addon 2 files and folders
-- libs
-- internal
-- internal lib1
-- internal lib2
-- external
-- external lib1
-- external lib2
我的库代码分为 2 个部分 - 核心代码和插件,我正在使用一些库(libs
文件夹)
我的愿望是:
最终结果:库.js核心.js插件1.js插件2.js
我的客户必须使用前 2 个 js 文件。和 Addon 将按照他们的意愿包含在内。
到目前为止,我已经成功使用 CommonsChunkPlugin
分离了我的内部库
new webpack.optimize.CommonsChunkPlugin({
name: "libs",
minChunks: function(module){
return module.context && module.context.indexOf("\\libs\\internal\\") !== -1;
},
});
使用null-loader
忽略外部库
{
test: /libs\\external/,
loader: 'null-loader'
},
我的入口点js看起来像这样
导入自
"./core/a";
import b from "./core/b";
import addon1C from "./addons/addon1/c";
const myLib = {
core: {a,b},
addons: {addon1C}
}
export {myLib}
现在问题始于核心和插件。
如果我跳过插件部分,在我的客户端包括 2 个脚本(库、核心)
并且myLib.core.a
正在工作。
问题是我是否要阻止插件中核心代码的捆绑。
我尝试使用另一个 block 插件来完成此操作,但它会在模块中导致一些错误,因为插件正在使用核心代码,并且入口点正在使用插件来导出它,因此它找不到模块.
尝试了 2 个入口点,所以我将拥有第一个没有插件的入口点并单独导出插件,但现在核心代码捆绑在其中。
那么,我该怎么做呢?或者是否有更好的方法来完成我迄今为止所做的任何事情。我很高兴学习。
最佳答案
为了实现这一目标,我认为您必须使用不同的方法。我遇到过类似的情况,其他一些团队需要按需扩展应用程序的核心功能。
为了实现这一目标,我必须确保核心和附加组件不会直接相互通信。相反,您的核心代码应该提供某种可供您的附加组件使用的 API。
从另一端来看,当您的附加组件尝试导入核心时,您必须提供一个 shim
文件,而不是核心本身。
我会尝试在这里写几个例子:
// core
export default const Core = {}
const addons = []
Core.addPlugin = function(addOn) {
addons.push(addOn) // or doing something else
}
// shim-core.js
export default typeof window.Core !== undefined ? window.Core : Core
// add-on
import Core from 'shim-core'
const addOn = function() {
// something funky
return {}
}
Core.addPlugin(addOn)
希望它能帮助您理解“架构”
关于node.js - 将我的库分为库、核心和插件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44387163/
我有一个数组列表: ArrayList allText = new ArrayList(); 其内容是这样的: [Alabama - Montgomery, Alaska - Juneau, Ariz
我有一个 timestamp 格式的开始和结束时间。我想将它们分成多个时间段,例如 1 小时。 $t1 = strtotime('2010-05-06 12:00:00'); $t2 = strtot
我需要将 span10 分成 3 列,但我无法将它们排列起来。我应该在 span10 中添加一个 span12 还是使用 offset 还是??
我有一个时间序列。我想从早上 8 点到第二天早上 7:59 分成 24 小时的区 block 。我知道如何按日期分组,但我尝试过使用 TimeGroupers 和 DateOffsets 处理这个 8
我收到“街道号码邮政编码城市”形式的地址(作为字符串)。我想要做的是将街道和号码与邮政编码和城市分开。通常你可以按空格分割。但有些街道名称中也有空格,例如:“Emile Van Ermengemlaa
我有一个用户列表。其中一些用户处于第一状态,而其他用户处于第二状态。所以我想要的是将这个列表显示为首先,它按排序顺序显示存在 = 1 的用户,然后按排序顺序显示存在 = 2 的用户。这里的排序是根据用
我感觉我搜索了整个网络,但找不到一种方法将不同高度的 div 很好地划分为 3 列,就像 http://www.ing.nl 上那样 headertekst headerteksttesth
Bootstrap 3 按钮下拉菜单出现问题。你可以在这里看到我的两个例子: http://www.bootply.com/W1dLusilMk http://www.bootply.com/GGBv
我在 php 中执行以下操作 foreach($QuestionAsekd as $k => $v){ $grp_name = $v['NAME']; $groupValues[$gr
我找到了一种用pandas解析html的绝妙方法。我的数据格式有点奇怪(见下文)。我想将这些数据拆分为 2 个单独的数据帧。 注意每个单元格如何由,分隔...是否有任何真正有效的方法来分割所有这些单元
HTML 看起来像这样,但我不允许对其进行更改。我只能编写 CSS 将其变成 2 列。 Povezave www.behance.net www.kiberpipa.org www.o
假设我有以下数据框“A” utilization utilization_billable service 1
我需要将 2 个文本框拉伸(stretch)到 100% 的浏览器宽度,以及一个提交按钮。所有三个都应该在一行中,我试图拉伸(stretch)它但它没有发生......有什么想法吗? 代码: .sea
我是一名优秀的程序员,十分优秀!