我有两个下载列表来过滤内容。第一个是位置,第二个是工作。第一个列表过滤第二个。我正在使用:contains来读取允许我的过滤器工作的字符串值。当我想一次使用两个包含作为过滤器时,我遇到了问题。这是代码:
HTML
<div class="holder">
<label for="volunteerLocation">Where do you want to volunteer?</label><br>
<select id="locations">
<option value="0">--Select a Campus--</option>
<option value="5">Location 1</option>
<option value="6">Location 2</option>
<option value="7">Location 3</option>
</select>
</div>
<br />
<div class="holder">
<label for="volunteerJobs">In which area would you like to serve?</label><br />
<select id="jobs">
<option value="1">Job 1 (Location 1)</option>
<option value="2">Job 2 (Location 2)</option>
<option value="3">Job 3 (Location 3)</option>
<option value="4">Job 4 (All locations)</option>
</select>
</div>
的Javascript
var select = $('#jobs');
var options = [];
$(select).find('option').each(function () {
options.push({ value: $(this).val(), text: $(this).text() });
});
$(select).data('options', options);
$('#locations').change(function () {
filterText = $("#locations option:selected").text();
var optionList = $(select).empty().data('options');
var j = 0;
$.each(optionList, function (i) {
var option = options[i];
if (option.text.indexOf(filterText) !== -1) {
if (j == 0) {
$('#jobs').prepend("<option value=''>--Select a Job--</option>").val('');
j++;
};
$(select).append(
$('<option>').text(option.text).val(option.value)
);
}
if (filterText == "--Select a Campus--") {
$(select).append(
$('<option>').text(option.text).val(option.value)
);
}
})
})
这是一个JSLint,所以你可以在行动Full Example
中看到它我正试图让“工作4”出现在除“选择校园”选项之外的所有内容上。我该怎么做?
答案 0 :(得分:0)
而不是每次位置更改时使用.each循环,并且通过异常,我会在页面加载时创建索引
var locJobs=new Array();
然后用数据填充它,例如
locJobs['5']=new Array();
locJobs['5'] = ['job 1','job 2']
然后改变
$("#jobs").html('<option>'+locJobs[$(this).val()].join('</option><option>')+'</option>');
如果您需要在#jobs的选项中添加值,则必须使该片段复杂化。 它应该更有效率和更高还可以使维护变得更加容易(没有例外处理只使用数组来填充您正在使用的任何数据源),因为您最终会得到一个非常灵活的解决方案
nb:你声明var select = $("#jobs")
但是你使用$(select);这是一个无用的开销直接使用select
保持代码清晰的约定是将$添加到缓存jquery对象的任何变量:
var $select=$("#select")
然后你使用$select.whtever(//...