jQuery 循环将多个数组放在一起 - Mapbox map.setFilter()
jQuery loop to put together multiple arrays - Mapbox map.setFilter()
Mapbox 的新 GL API 被证明难以使用。我想知道我是否可以通过 jQuery 的每个函数构建一个具有这种奇怪格式的数组。
我正在创建一个带有类别复选框的表单,用于过滤地图上显示的标记。我正在使用 $.each()
循环来获取选中的输入,获取它们的 ID,并将其放在每个数组的中间。一个选中的输入是一个数组。
基本上,我需要这样将数组放在一起:
map.setFilter('markers', ["any",
['in',c1,true],
['in',c2,true], // these 3 arrays
['in',c3,true]
] );
但显然,我需要在检查时动态完成此操作。这是我想使用的不完整 jQuery:
jQuery('input.checkbox-child').change(function(){
args = new Array();
jQuery('input.checkbox:checked').each(function(){
id = jQuery(this).attr('id');
filter = ['in',id,true];
// ???
});
map.setFilter('markers', ["any", args] );
});
不确定如何将 filter
变量连接在一起形成逗号分隔的数组列表,类似于 ['in',id,true],['in',id,true],['in',id,true]...
用于 setFilter 函数。
我认为这应该可以满足您的需求
var args = [];
jQuery('input.checkbox-child').change(function(){
jQuery('input.checkbox:checked').each(function(){
var id = jQuery(this).attr('id');
var filter = ['in',id,true];
args.push(filter);
});
map.setFilter('markers', ["any"].concat(args));
});
Mapbox 的新 GL API 被证明难以使用。我想知道我是否可以通过 jQuery 的每个函数构建一个具有这种奇怪格式的数组。
我正在创建一个带有类别复选框的表单,用于过滤地图上显示的标记。我正在使用 $.each()
循环来获取选中的输入,获取它们的 ID,并将其放在每个数组的中间。一个选中的输入是一个数组。
基本上,我需要这样将数组放在一起:
map.setFilter('markers', ["any",
['in',c1,true],
['in',c2,true], // these 3 arrays
['in',c3,true]
] );
但显然,我需要在检查时动态完成此操作。这是我想使用的不完整 jQuery:
jQuery('input.checkbox-child').change(function(){
args = new Array();
jQuery('input.checkbox:checked').each(function(){
id = jQuery(this).attr('id');
filter = ['in',id,true];
// ???
});
map.setFilter('markers', ["any", args] );
});
不确定如何将 filter
变量连接在一起形成逗号分隔的数组列表,类似于 ['in',id,true],['in',id,true],['in',id,true]...
用于 setFilter 函数。
我认为这应该可以满足您的需求
var args = [];
jQuery('input.checkbox-child').change(function(){
jQuery('input.checkbox:checked').each(function(){
var id = jQuery(this).attr('id');
var filter = ['in',id,true];
args.push(filter);
});
map.setFilter('markers', ["any"].concat(args));
});