以编程方式声明dijit.form.select的值

时间:2011-08-23 20:08:37

标签: javascript dojo dijit.form

我正在尝试通过JSON声明声明标记声明的dijit.form.Select小部件的选项。基于我在API文档中读到的内容,您似乎可以使用setStore()传递新商店,然后它应该更新,但除了带有完整商店的空Select小部件之外,这并没有产生任何有用的结果。我想知道我的对象是否缺少某些声明,如果我使用了错误的方法,或者是否有其他方法来声明这些选项。

我一直在使用的测试标记打印在下面:

<!DOCTYPE HTML>
<html dir="ltr">

    <head>
        <style type="text/css">
            body, html { font-family:helvetica,arial,sans-serif; font-size:90%; }
        </style>
        <script src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js"
        djConfig="parseOnLoad: true">
        </script>
        <script>
            dojo.require("dijit.form.Select");
            dojo.require("dojo.data.ItemFileReadStore");
            dojo.require("dojo.data.ItemFileWriteStore");
        </script>
        <link rel="stylesheet" type="text/css" href="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dijit/themes/claro/claro.css" />
    </head>

    <body class=" claro ">

        <div class="option" id="option" dojoType="dijit.form.Select"></div>

        <script type="text/javascript">
            dojo.addOnLoad(function() {
                if (document.pub) {
                    document.pub();
                }

                var selectOptions = {
                    name:'selection', 
                    identifier: 'label',
                    options: [{
                        label: 'this',
                        value: '01'
                    },
                    {
                        label: 'that',
                        value: '02'
                    },
                    {
                        label: 'the other',
                        value: '03'
                    },
                    {
                        label: 'banana',
                        value: '04',
                    },
                    ]};

                    var aStore = dojo.data.ItemFileReadStore({data: selectOptions});
                    dijit.byId("option").setStore(aStore, 01);
                    dijit.byId("option").startup();

            });
        </script>
    </body>

</html>

2 个答案:

答案 0 :(得分:7)

正如@missingno所提到的,使用商店可能有点过头了。你可以使用

dijit.form.select.addOption(/*array of options*/).

从你的例子中可以看出:

var listOfOptions = [{
    label: 'this',
    value: '01'
  },
  {
    label: 'that',
    value: '02'
  },
  {
    label: 'the other',
    value: '03'
  },
  {
    label: 'banana',
    value: '04',
  },
  ];
dijit.byId("option").addOption(listOfOptions);

答案 1 :(得分:2)

我认为你错过了初步的商店。选项看起来像用于初始化普通选择的选项。尝试做类似的事情:

http://dojotoolkit.org/reference-guide/dojo/data/ItemFileReadStore.html

var store_options = {
    identifier: 'label',
    label: 'label',
    items: [
        {label: 'this', value:'01'},
        //...
    ]
}

var store = dojo.data.ItemFileWriteStore({data: store_options})

OTOH,你确定你需要使用商店吗?除非您想使用特定商店功能(如通知),否则只需在以编程方式创建选择时直接传递数据:http://dojotoolkit.org/reference-guide/dijit/form/Select.html