首先,我们是Dojo的新手并且可以通过“新”方式自由地做事,所以我大多忽略了文档的前1.7部分。不过,在比较各种文章,文档和示例脚本时,我会感到困惑。
最重要的是,我找不到关于如何为Dojo创建和部署自定义构建的直截了当的说明。更具体地说,我们需要部署哪些.js和.css文件。有很多documentation on creating a build,但我在部署时找不到。
我最终收集了将所有内容构建到单个dojo.js是一个合理的移动实践,我只需要从构建目录中提取一个文件并将其部署到我的服务器,但后来我失去了CSS引用,似乎试错法不是解决这些问题的正确方法。
以下是我们具体的当前案例:
<script type="text/javascript">
require(
// deviceTheme to auto-detect device styles
[
"dojox/mobile",
"dojox/mobile/parser",
"dojox/mobile/deviceTheme"
]);
</script>
这是构建配置文件:
dependencies = {
stripConsole: "normal",
layers: [
{
name: "dojo.js",
customBase: true, // prevent automatic inclusion of dojo/main
dependencies: [
"dojox.mobile.parser",
"dojox.mobile",
"dojox.mobile.deviceTheme"
]
}
],
prefixes: [
[ "dijit", "../dijit" ], // example included; not clear why
[ "dojox", "../dojox" ]
]
}
(由dojo-release-1.7.2-src\dojox\mobile\build\build.bat
脚本执行。)
所以我猜具体的问题是:
mobile-all.profile.js
使用dependencies=
而不是1.7 build tutorial描述的profile=
? 答案 0 :(得分:8)
这是有条件的,如果页面使用特定模块并且它有自己的css规则,则包含它们。
这不是 方式,而是从dojo.css(base,reset),dijit.css(base,layouts等),nihilo.css(示例主题)和android开始。 css(示例主题)将奠定良好的基础
通过'thumbrule',任何1.6+文档都是稳定的,但他们大多数都是一样的。当你启动一个配置文件时,它可能会有一些试验和错误(脚本文件的内联html包含的顺序是最重要的)。你发布的内容看起来不错,但考虑一下customBase:true是否是必要的。
确保版本1.6-1.7和seen this
有version 1.8您可以使用现有的包装盒。然而,建设者正在发生变化,与备受争议的2.0版本相抗衡。目前,新计划以及常规计划都是允许的。但实际上变量名称可以是foo或bar,只有变量的值可以使用。该文件必须“返回”一个对象。
据我所知,原因是CommonJS Packages/1.0是AMD和构建者1.7+的新圣经。不过,它始终是包装层次所遵循的“拇指”方案 - 但是随着我们越接近2.0,语法很可能变得越来越严格。 (看看你是否可以在#dojo @ irc.freenode.org上与snover联系)