<div id="filters"></div>
<div id="filtered"></div>
const arr = [
'italy', 'usa', 'spain', 'usa', 'usa',
'france', 'spain', 'france', 'usa',
'italy', 'spain', 'usa', 'france'
];
const filters = document.querySelector('#filters');
filters.innerHTML = Array
.from(new Set(arr), n => `<label><input type="checkbox" value="${n}">${n}</label>`)
.join('');
filters.addEventListener('change', function() {
const checked = Array.from(this.querySelectorAll(':checked'), n => n.value);
document.querySelector('#filtered').innerHTML = arr
.filter(n => checked.includes(n))
.map(n => `<span class="${n}">${n}</span>`)
.join(', ');
});
#filtered {
font-size: 48px;
}
.italy { color: green; }
.spain { color: yellow; }
.france { color: blue; }
.usa { color: red; }
смотреть я умею
что можно понять с сообщения "is not a function"?
Куда уж проще-то: