【问题标题】:jQuery: How can I create an object of arrays with variables setting the number of object keys and the key value itself?jQuery:如何使用变量设置对象键的数量和键值本身来创建数组对象?
【发布时间】:2011-03-25 21:41:06
【问题描述】:

我正在努力解决这个问题,希望您能提供帮助。

我的目标是创建arrays 中的object,其中每个key 都由variable 设置,并且此keyvalues 是另一个array 的过滤结果。

好的,写起来很复杂,下面是一个例子:

<!-- Markup -->
<section id="container">
    <article class="class-1">1</article>
    <article class="class-2">2</article>
    <article class="class-3">3</article>
    <article class="class-4">4</article>
    <article class="class-5">5</article>
    <article class="class-6">6</article>
    <article class="class-7">7</article>
    <article class="class-8">8</article>
    <article class="class-9">9</article>
</section>

//  Desired outcome:
//  plugin variables are
    { columns:3 }

var cols = {
    1 : [ $('.class-1') , $('.class-4') , $('.class-7') ],
    2 : [ $('.class-2') , $('.class-5') , $('.class-8') ],
    3 : [ $('.class-3') , $('.class-6') , $('.class-9') ]
};

// my jQuery so far:
// note : columns == 3

var cols =  $.map( $('article','#container') , function(item, i) {
                return {[ i%columns+1 : item ]};
            });

我怎样才能在这里实现我所需要的? 我做错了什么?

任何帮助将不胜感激。

感谢阅读,

詹尼斯

【问题讨论】:

    标签: jquery arrays object map


    【解决方案1】:

    我想我明白你在做什么。您希望文章在加载时自动排序到列地图中,对吗?

    我认为.map 不会让你到达那里,因为它会返回一个数组。在您想要的输出中,您有一个包含每列键的对象。我认为您想要的是以下内容:

    var columns = 3;
    var cols = {};
    
    $(document).ready(function(){
        $('article','#container').each(function(index, value){
            var col = index%columns + 1;
            if(cols[col] === undefined){
                cols[col] = [$(value)];
            } else {
                cols[col].push($(value));
            }
        });
    });
    

    【讨论】:

    • 正是我想要创建的,非常感谢!
    【解决方案2】:

    如何about like this:

    var mapFunc = function(){ return $(this); },
        articles = $('#container article'),
        info = { columns: 3 },
        cols = {
            '1': articles.filter(':nth-child(3n + 1)').map(mapFunc).get(),
            '2': articles.filter(':nth-child(3n + 2)').map(mapFunc).get(),
            '3': articles.filter(':nth-child(3n + 3)').map(mapFunc).get()
        };
    

    或者对于更动态的方法:

    cols = {};    
    for(var i = 1; i <= info.columns; i++)
        cols[i] = articles
            .filter(':nth-child(' + info.columns + 'n + ' + i + ')')
            .map(mapFunc).get()
    

    【讨论】:

    • 感谢您的解决方案,在这种情况下我更喜欢 RSG 的解决方案,但无论如何(尤其是第二种解决方案)都很棒,我会记住它以备将来使用。再次感谢。
    猜你喜欢
    • 1970-01-01
    • 2013-12-02
    • 2015-03-22
    • 2016-12-31
    • 2021-08-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多