用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(); });