我正在尝试访问组合框的所选选项的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>
我正在试图弄清楚出了什么问题。我可以帮帮我。非常感谢!
答案 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);
}