0

私は持っています:

function isLong(val)
{
    if(val.length > 4){
       return true;
    } else {
        return false;
    }
}

var page = [{
    title: 'aaa',
    text: '111'
}, {
    title: 'bbb',
    text: '222'
}, {
    title: 'ccc',
    text: '333'
}, {
    title: 'ddd',
    text: '444'
}, {
    title: 'eee',
    text: '444'
}];

console.log([].concat.apply([], '222, 333, 4441, long1, long, long2'.split(', ').map(function (t) {
    return page.filter(function (o) {
        return o.text === t || isLong(t);
    }).map(function (c) {
        return c.title
    });
})).join(", "));

jsfiddle

しかし、これはすべての値を返します。これを行で確認してみます return o.text === t || isLong(t);

この例では、受け取りたい:

bbb、ccc、long1、long2

bbb と ccc はオブジェクト ページからのものです。long1 と long2 は、コンマで区切られたカスタム文字列の形式です。

4

1 に答える 1

1
var str = '222, 333, 4441, long1, long, long2';

var strArray = str.split(', ');

var result = strArray.map(function(s){
    return isLong(s) ? s : page.filter(function(o){ // if word has > 4 chars return word else try to match with page array
       return o.text == s; 
    }).map(function(c){
      return c.title;  // if matched return title
    })[0]; // select first match
}).filter(function(u){
    return u;  // remove undefined results
});

console.log(result);

例: http://jsfiddle.net/YrZNq/6/

于 2013-09-25T21:24:12.500 に答える