【转】dojo使用方法(xmlhttp dojo.xhrGet)
xmlhttp dojo.xhrGet
OK,介绍了简单的DOM操作方法,接下来该到Ajax的传统项目-XmlHttp了。
在使用xmlhttp时,需要注意到编码的问题,要让dojo默认绑定为utf-8怎么办呢?很简单,只需要修改一下引入dojo.js时的标签:
<script type="text/javascript" src="./dojo-lib/dojo/dojo.js" djConfig="isDebug:true,bindEncoding:'UTF-8'"></script>
多了一个djConfig属性,很简单,
第一个isDebug是说是否打开FireBug的Console,
第二个是xmlhttp使用的编码。第二个才是重点,设置了就一劳永逸了。
这次我们要点击了hello按钮后发出一个xmlhttp请求:
function sayHello() { dojo.xhrGet({ url: "http://localhost/hello/sayHello.jsp", handleAs: "text", load: function(responseText) { alert(responseText); dojo.byId("divHello").innerHTML = responseText; }, error: function(response) { alert("Error"); } }); }
dojo.connect(btn,"onclick",sayHello);
看看,够不够一目了然?
url 就是url…… ;
handleAs 把获取的内容作为text/html ;load 成功时的回调函数;error 失败时的回调函数
那如果要传入参数怎么办?
var params = { username:'Mark', id:'105' }
dojo.xhrGet({ url: "http://localhost/hello/sayHello.jsp", content:params, //... });
注意那个content参数,你要传入的参数是个关联数组/object,dojo会自动把参数解析出来,要使用post方法?
dojo.xhrGet ---> dojo.xhrPost ,其他的还有,dojo.xhrPut、dojo.xhrDelete。 (
为什么我用dojo.parser.parse(dom节点)两次会出错
问题:
我想用分部分加载HTML到页面,当把上一次加载进来parse后,再点一下加载HTML进来parse就出错了.请问这是为什么,或者说如何做到可以多次加载HTML进来并转换为dojo类型的节点
解答:
dojo的parser会把html节点根据所声明的类型(data-dojo-type)转化为相应的dijit组件的template(dojo类型的节点),并且会给这些相应的template赋上对应的id,属性等等,并且把组件的id注册到dijit.registry里。在注册到registry的过程中,如果没有显式的指定id,则registry会生成一个自增的id赋值给相应的组件,如果显式的指定id,则使用指定的id。如果对同一节点多次parse操作,并且这些节点中有指定id的情况,就会出现你说的这种情况,报的错应该是Tried to register widget with id==xxx but that id is already registered。如果想分步加载并且多次parse,可以加载一个节点parse一个节点。或者在代码中调用dijit组件的startup方法也可实现parse的同样效果。