Что именно возвращает $(...). Map()? - программирование
Подтвердить что ты не робот

Что именно возвращает $(...). Map()?

Учитывая это:

<a href="1">1</a>
<a href="2">2</a>

Вот функция, возвращающая массив значений href:

e = $('a').map(function(v) { return $(this).attr('href'); });
console.log(e);

Но он дает

["1", "2", prevObject: x.fn.x.init[2], context: document, jquery: "1.10.2", constructor: function, init: function…]

Как я могу изменить это, чтобы возвращать необработанный массив [ "1", "2" ]?

4b9b3361

Ответ 1

Это потому, что jQuery.fn.map возвращает новый объект jQuery, вы должны использовать jQuery.fn.get для получить массив:

var a = $('a').map(function(v, node) { 
    // v is the index in the jQuery Object, 
    // you would maybe like to return the domNode or the href or something: 
    // return node.href;

    return v; 
}).get(); // <-- Note .get() converts the jQuery Object to an array

Микро-оптимизация:

Если вы посмотрите на исходный код для jQuery.fn.get, вы увидите, что он указывает на jQuery.fn.toArray:

function ( num ) {
    return num == null ?

        // Return a 'clean' array
        this.toArray() :

        // Return just the object
        ( num < 0 ? this[ this.length + num ] : this[ num ] );
}

Итак, вы также можете позвонить:

$('a').map(...).toArray();