我目前正在尝试在requirejs optimiser config中创建单独的模块,目前看起来像: 基于模块的设置(无法跳过facebook路径):
({
baseUrl: '../static/js',
mainConfigFile: '../static/js/main.js',
dir: '../static/js/deploy',
paths:{
requireLib: 'vendor/require/require.min',
_core: 'minify_modules/_core',
search: 'minify_modules/_search'
},
modules:[
{
name: 'main',
include: ['requireLib', '_core']
},
{
name: 'search',
include:['search']
}
]
})
在我的一个requirejs模块中,我需要facebook SDK。当我运行优化器时,优化器无法跳过目录并报告:
错误:JavaException:java.io.FileNotFoundException:/connect.facebook.net/en_US/all.js(没有这样的文件或目录)
最初我使用的是非模块方法并且只有一个输出文件。当我运行该设置时,它会跳过像Facebook SDK这样的外部资源,所以我显然有点困惑为什么以下设置会跳过目录并且上面的基于模块的设置不会。
基于非模块的设置(跳过脸书路径)
({
baseUrl: '../static/js',
mainConfigFile: '../static/js/main.js',
name: 'main',
out: '../static/js/yb-scripts.min.js',
paths: {
requireLib: 'vendor/require/require.min',
_core: 'minify_modules/_core'
},
include: ['requireLib', '_core']
})
Facebook SDK在main.js配置文件中引用:
facebookSDK: '//connect.facebook.net/en_US/all',
我一直在尝试按照这里的优化注释:LINK
答案 0 :(得分:2)
您可以在paths
属性中指定跳过最小化某个模块,因为它是从外部资源提供的:
paths: {
requireLib: 'vendor/require/require.min',
_core: 'minify_modules/_core',
facebookSDK: 'empty:'
},
有关详细信息,请参阅RequireJS docs for empty:
。
另一方面,我没有意识到单个文件的优化过程实际上会默认跳过外部资源。我通常仍然为所有JS库指定empty:
,因为我使用带有回退的CDN,例如jquery: ["http://code.jquery.com/jquery-1.10.1.min", "../bower_components/jquery/jquery.min"]
。