当前位置 : 主页 > 网页制作 > Dojo >

dojo小例子(13)给Select指定id及label

来源:互联网 收集:自由互联 发布时间:2021-06-15
用store为Select提供数据时,store中的数据必须带有id和label属性。实际情况是我们的数据格式多种多样,不一定带有id和label。这时可以用Select的labelAttr指定数据中的哪个属性作为label。但

用store为Select提供数据时,store中的数据必须带有id和label属性。实际情况是我们的数据格式多种多样,不一定带有id和label。这时可以用Select的labelAttr指定数据中的哪个属性作为label。但是只指定label不指定id,下拉菜单虽然可以显示出来,却无法选中。所以还必须指定一个属性作为id,用store的idProperty来指定id。Memory和JsonRest都有idProperty属性,但是直接给Select提供数据,显示出来的下拉菜单项是无序的,和数据的原始顺序不一致,所以还需要用ObjectStore包一下再给Select使用。

var json = new JsonRest({
	target: url
});

json.query().then(function(data) {
	var mem = new Memory({
		data: data,
		idProperty: "num" // data中的属性num作为id
	});
	var os = new ObjectStore({
		objectStore: mem
	});
	var select = new Select({
		name: "type",
		store: os,
		labelAttr: "name", // data中的属性name作为label显示
		style: "width: 150px;"
	}, "div_type");
	select.startup();
});
网友评论