您好,我正在动态地在 ul - li HTML 标记中填充一个列表。我所需要的只是获取相应 ul 的选定 li 的值。我尝试了所有可能的 jquery 方法,但仍然未定义。我将 ul - li 填充为:
jQuery.get(url, function(data) {
for(i=0;i<data.length;i++){
//console.log(data[i]) //"+data[i]+"
msg = "<li> <a href=#>"+data[i]+"</a></li>";
document.querySelector('#option1').innerHTML += msg;
}
});
HTML 部分如下:
<body>
<div class="wrap">
<div class="content">
<div class="cate-map">
<ul id="option1" onclick="doSelection()">
</ul>
</div>
</div>
<div class="content2">
<div class="cate-map">
<ul id="option2">
</ul>
</div>
</div>
<div class="clear"></div>
<div class="content3"> <textarea id="content4"></textarea>
</div>
</div>
</body>
onclick方法如下:
function doSelection(){
var id = $('#option1 li.selected').attr('value');
alert(id);
}
问题是我的 id 值“未定义”。
UPDATE
正如大家所建议的,我将代码更改为:
将 ul 填充为:
jQuery.get(url, function(data) {
for(i=0;i<data.length;i++){
msg = "<li data-input="+data[i]+" class='selected'> <a href=#>"+data[i]+"</a></li>";
document.querySelector('#option1').innerHTML += msg;
}
});
HTML ul 为:
<div class="cate-map">
<ul id="option1" onclick="doSelection()">
</ul>
</div>
Onclick 函数为:
function doSelection(){
alert($('#option1 li.selected').attr('data-input'));
}
现在我得到一个警报值,但我总是得到第一个元素作为警报。无论我单击哪个元素,仍然总是获取列表的第一个元素。请帮忙。