djConfig是dojo内置的一个全局设置对象,其作用是可以通过其控制dojo的行为 首先我们需要在引用dojo.js前声明djConfig对象,以便在加载dojo.js的时候才能够取得所设置的值,虽然在0.3版本以后dojo支持在加载后设置,但是强烈建议你把声明djConfig的代码作为第一段script 一个完整的djConfig对象定义如下(值均为dojo的默认值) <scripttype="text/javas cript"> vardjConfig={ isDebug:false, debugContainerId:"", allowQueryConfig:false, bases criptUri:"", parseWidgets:true searchIds:[], baseRelativePath:"", librarys criptUri:"", iePreventClobber:false, ieClobberMinimal:true, preventBackButtonFix:true, }; </s cript> isDebug是一个很有用的属性,顾名思义,如果设置为真,则所有dojo.Debug的输出有效,开发时应该设置为true,发布时应该设置为false 同样也是与调试有关的,如果不指定的话,调试信息将会直接利用document.write输出,这样可能会破坏页面的整体布局,所以你可以指定任何一个可以作为容器的html元素的id作为调试信息输出容器 ,这个属性指明dojo是否允许从页面url的参数中读取djConfig中的相关属性,当值为true时,dojo会优先从url参数中读取djConfig的其他属性,比如:http://server/dojoDemo.htm?djConfig.debugContainerId=divDebug ,一般不需要设置,dojo会自动根据你引用dojo.js的路径设置这个值,比如,<s cripttype="text/javas cript"src="../dojo/dojo.js"></s cript>,自动获取的值便是../dojo/ ps:如果你有多个工程需要同时引用dojo.js的话,建议也把dojo当作一个独立的工程,引用的时候采用绝对路径就可以了
parseWidgets ,这个是可以控制 dojo 是否自动解析具有 dojoType 的 html 元素为对应的 widget ,如果你没有使用任何 Widget ,建议设置为 false 以加快 dojo 的加载速度 ,这是一个字符串数组,定义了所有需要解析为 widget 的 html 元素的 ID ,如果 ID 不在其中的 html 元素是不会被解析的,当数组为空数组时,则所有具有 dojoType 的元素都会被解析 至于其它的属性,不是用处不大,就是不知道有什么作用 在实际开发中,可以把 djConfig 的定义放在一个 js 文件里,并将其作为第一个引用的 js 文件,这样应该是最方便的。debugContainerId
allowQueryConfig
bases criptUri
searchIds