无法获取组合框的值

时间:2012-12-19 19:32:50

标签: javascript combobox dojo

我正在尝试访问组合框的所选选项的text属性。以下代码是我到目前为止所处的位置,但我无法识别代码中的错误。

<!DOCTYPE html>
<html >
<head>
<link rel="stylesheet" href="dijit/themes/claro/claro.css">
<style type="text/css">
table,td
{
border: 1px solid black;
}
td
{
height:30px;
vertical-align:center;
padding:15px;
}
.tableClass
{
    border:1px;
    border: 1px solid black;
}
</style>
<script src='dojo/dojo.js' data-dojo-config='parseOnLoad: true'></script>
<script>
//require(["dojo/parser", "dijit/form/FilteringSelect", "dojo/store/Memory"]);

</script>
<script type="text/javascript">
    dojo.require("dijit.form.ComboBox");
    function alterEntries()
        {
            //alert("in");
            document.getElementById('overlayName').value = dijit.byId('stateSelect').value;

            dojo.style("description", {
                display:"block",
            });
            dojo.style("overlayName", {
                display:"block",
            });
        }
        function submitEntries(ovlName,overlayDescription)
        {
            var textOfOvl = getSelectedText(ovlName);
            alert("overlayName " + ovlName + " overlayDescription " + overlayDescription);
        }

        function getSelectedText(elementId) 
        {
            var elt = document.getElementById(elementId);

            if (elt.selectedIndex == -1)
            {
                alert("null");
                return null;
            }

            return elt.options[elt.selectedIndex].text;
        }

    </script>

</head>

<body class="claro">
    <select id="stateSelect" data-dojo-type="dijit.form.ComboBox">
        <option value="AL">Alabama</option>
        <option value="AK">Alaska</option>
        <option value="AZ">Arizona</option>
        <option value="AR">Arkansas</option>
        <option value="CA">California</option>
    </select>
     <input name="overlayName" type="text" value="overlayName" id="overlayName"  style="display:none">
    <textarea name="description" cols="50" rows="3" id="description" style="display:none"></textarea>
    <p>
        <button onclick="alterEntries();">EDIT</button>
        <button onclick="submitEntries(document.getElementById('overlayName').value,document.getElementById('description').value);">SUBMIT</button>
    </p>


</body>

</html>

我正在试图弄清楚出了什么问题。我可以帮帮我。非常感谢!

2 个答案:

答案 0 :(得分:3)

您选择的文字应如下所示,以获取显示的文字:

function getSelectedText(el){
     var text = dijit.byId(el).get('displayedValue'),
     value = dijit.byId(el).get('value');
     alert(text);
     return text;
}

我建议你查看基本的dijit教程,当使用dijits时,document.getElementById会产生一个与dijit.byId完全不同的结果。

这也是输入中的轻微修正

 <input name="overlayName" type="hidden" value="stateSelect" id="overlayName">

我也建议你使用

dojo.byId('textId');

而不是document.getElementById

答案 1 :(得分:1)

你的代码非常奇怪。我可以在线上理解它

<input name="overlayName" type="text" value="overlayName" id="overlayName" style="display:none">

value属性必须设置为stateSelect,但不能设置为overlayName

要查看submitEntries函数的浏览器更改实现中的任何工作结果:

function submitEntries(ovlName,overlayDescription)
{
    var textOfOvl = getSelectedText(ovlName);
    alert(textOfOvl);
}

请参阅working modification of your code