Lodash 在数组中通过 startswith 搜索
Lodash search by startswith in an array
我正在创建一个简单的搜索,用于搜索以从输入传递的字符串开头的对象数组。
所以我有这个:
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']},
];
input.on(function(e) {
var test = _.filter(items, function(item) {
return _.includes(_.pluck(items, 'tags'), input.val());
});
console.log(test);
});
这总是 returns 一个空数组,我想我遗漏了 startsWith
,我如何在我的实现中使用它:
预期的输出应该是:
input: 'f'
output: [{id: 1, tags: ['foo']}, {id: 2, tags: ['fish', 'ball']}]
因为这两个项目的标签以 f
开头
试试这个:
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']}
];
input.on(function(e) {
var test = _.filter(items, function(item) {
return _.chain(items.tags)
.map(_.partial(_.startsWith, _, input.val()))
.any()
.value();
});
console.log(test);
});
试试这个:
$(function(){
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']},
];
var input = $('input:first');
input.on('input', function(e) {
var test = _.filter(items, function(item) {
for(var t in item.tags) {
if(item.tags[t].indexOf(input.val())==0) {
return true;
}
}
return false;
});
console.log(test);
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://raw.githubusercontent.com/lodash/lodash/3.10.0/lodash.min.js"></script>
<input>
基本上,您不需要 lodash:
var test = items.filter(function (item) {
return item.tags.some(function (tag) {
return 0 === tag.indexOf(input.val());
});
});
但如果你喜欢,你可以使用它
var test = _.filter(items, function (item) {
return _.some(item.tags, function (tag) {
return _.startsWith(tag, input.val());
});
});
我正在创建一个简单的搜索,用于搜索以从输入传递的字符串开头的对象数组。
所以我有这个:
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']},
];
input.on(function(e) {
var test = _.filter(items, function(item) {
return _.includes(_.pluck(items, 'tags'), input.val());
});
console.log(test);
});
这总是 returns 一个空数组,我想我遗漏了 startsWith
,我如何在我的实现中使用它:
预期的输出应该是:
input: 'f'
output: [{id: 1, tags: ['foo']}, {id: 2, tags: ['fish', 'ball']}]
因为这两个项目的标签以 f
试试这个:
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']}
];
input.on(function(e) {
var test = _.filter(items, function(item) {
return _.chain(items.tags)
.map(_.partial(_.startsWith, _, input.val()))
.any()
.value();
});
console.log(test);
});
试试这个:
$(function(){
var items = [
{id: 1, tags: ['foo']},
{id: 2, tags: ['fish', 'ball']},
{id: 3, tags: ['bar', 'goo']},
];
var input = $('input:first');
input.on('input', function(e) {
var test = _.filter(items, function(item) {
for(var t in item.tags) {
if(item.tags[t].indexOf(input.val())==0) {
return true;
}
}
return false;
});
console.log(test);
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://raw.githubusercontent.com/lodash/lodash/3.10.0/lodash.min.js"></script>
<input>
基本上,您不需要 lodash:
var test = items.filter(function (item) {
return item.tags.some(function (tag) {
return 0 === tag.indexOf(input.val());
});
});
但如果你喜欢,你可以使用它
var test = _.filter(items, function (item) {
return _.some(item.tags, function (tag) {
return _.startsWith(tag, input.val());
});
});