作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在我的 jquery 多选中使用 javascript 动态生成选项值。
function prova(data){
var t = 0;
var tmp = new Array();
var keys = new Array();
$("#select-1").multiselect({
multiple: true,
header: true,
noneSelectedText: "Select an Option",
selectedList: 1
});
var stringa ="";
$.each(data, function(key,value){
stringa +="<option value=\""+key+"\">"+key+"</option>";
if(t==0){
tmp[0] = key;
}
t++;
});
$("#select-1").html(stringa);
}
我在#select-1 中生成的值是这样的:
<select id="select-1" size="5" name="example-basic" title="Basic example" style="display: none;">
<option value="name1">name1</option>
<option value="name2">name2</option>
<option value="name3">name3</option>
<option value="name4">name4</option>
<option value="name5">name5</option>
</select>
问题是它没有将选项值填充到 jquery 多选中,它仍然是空的。
最佳答案
因为您直接在元素上使用 .html() ,所以您在插入新元素之前替换了其中的元素。你可能想像这样使用 .append() :
$.each(data, function(key,value){
stringa +="<option value=\""+key+"\">"+key+"</option>";
if(t==0){
tmp[0] = key;
}
t++;
});
$("#select-1").append(stringa);
或者在 .html() 用法中也使用以前的值:
$.each(data, function(key,value){
stringa +="<option value=\""+key+"\">"+key+"</option>";
if(t==0){
tmp[0] = key;
}
t++;
});
$("#select-1").html($("#select-1").html()+stringa);
关于javascript - 如何从js生成选项值到jquery multiselect,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29806154/
我是一名优秀的程序员,十分优秀!