I have task to receive unique element in order from string as parameter. I do not understand how this function uniqueElements returns [\'A\',\'B\',\'C\',\'B\']
The aim of [].filter.call
here is to apply the filter
method on a string. Naively you would first try to do this:
return word.filter(function(elem,index) {
return word[index-1] !== elem;
});
... which -- if word
were an array -- would return the characters in it that satisfy the condition word[index-1] !== elem
(which is short for word[index-1] !== word[index]
), i.e. each character that is different from the character that precedes it.
But, the filter
method only exists on objects that inherit from the Array
prototype, which is not the case for strings.
However, filter
itself can deal with array-like objects, i.e. objects that have a length
and potentially have properties that are numerical. To call filter
without a true Array
object, you can use call
on that function, and then provide the context (i.e. the array-like object) as first argument. The other argument(s) remain the same. So you first need to know where to find the filter
method... It is on the Array.prototype
, so you would reference it like this:
Array.prototype.filter
But as all arrays have access to this method, it is shorter to just take an empty array, and reference its filter
method:
[].filter
Either of the two will work. Now you have to execute the call
method on it, and supply the array-like object you want to iterate over:
[].filter.call(words, ...)
The rest is like you would do with a true array: you provide the callback function:
return [].filter.call(word, function(elem,index) {
return word[index-1] !== elem
});
The return value is no longer a string. It is -- like filter
always returns -- an array: a real one -- it is created by the filter
method.
In ES6 you can write this in a more readable way, as there now is the Array.from
method, which can turn an array-like object to a true array. And then you can just continue with the filter
method:
return Array.from(word).filter(function(elem,index) {
return word[index-1] !== elem
});
The spread operator is yet another alternative provided by ES6:
return [...word].filter(function(elem,index) {
return word[index-1] !== elem
});