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

前端之家收集整理的这篇文章主要介绍了dojo小例子(13)给Select指定id及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();
});

猜你在找的Dojo相关文章