javascript - 如何从 json 对象中获取匹配元素的索引?

标签 javascript jquery json

var formRenderData = [{
  "type": "checkbox-group",
  "label": "Checkbox Group",
  "className": "checkbox-group",
  "name": "checkbox-group-1479370460494",
  "values": [{
    "label": "Option 1",
    "value": "option-1",
    "selected": true
  }, {
    "label": "Option 2",
    "value": "option-2"
  }, {
    "label": "Option 3",
    "value": "option-3"
  }]
}, {
  "type": "paragraph",
  "subtype": "p",
  "label": "Paragraph",
  "className": "paragraph"
}];

我正在使用 grep 来匹配对象。

var InputName = 'checkbox-group-1479370460494';
var InputType = 'checkbox-group';

var returnedIndex = $.grep(formRenderData, function(element, index){
    if(( (element.name == InputName) || (element.label == InputName)|| (element.name == InputName.substr(0,InputName.length - 2)) ) && element.type == InputType){
        return index;
    }
});

console.log(returnedIndex);

最佳答案

jQuery.grep 过滤数组,返回满足过滤功能的项目列表,同时保持原始数组不变。 (参见 the jQuery docs。)

我不确定你为什么要访问索引;我假设您想要访问满足过滤器的原始对象。这可以通过从过滤器函数返回 true 来完成,然后循环遍历 matches 数组。

var InputName = 'checkbox-group-1479370460494';
var InputType = 'checkbox-group';
var formRenderData = [{"type": "checkbox-group","label": "Checkbox Group","className": "checkbox-group","name": "checkbox-group-1479370460494","values": [{"label": "Option 1","value": "option-1","selected": true},{"label": "Option 2","value": "option-2"},{"label": "Option 3","value": "option-3"}]},{"type": "paragraph","subtype": "p","label": "Paragraph","className": "paragraph"}]

var matches = $.grep(formRenderData, function(element, index){
    if(( (element.name == InputName) || (element.label == InputName)|| (element.name == InputName.substr(0,InputName.length - 2)) ) && element.type == InputType){
        return true
    }
});

console.log(matches); // [Array]
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

关于javascript - 如何从 json 对象中获取匹配元素的索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41009545/

相关文章:

javascript - 如果子 div 不包含子 div,则隐藏父 div

jquery - Json 下拉列表

javascript - 将 JSON 分配给自动完成

javascript - 如何使用 jquery 从查询字符串中获取两个参数值?

javascript - Mediawiki 编辑器 reftoolbar 不见了?

javascript - 使用 JavaScript 隐藏/显示特定的 div

jquery - 切换 div,但一次只显示一个

javascript - 点击时启用/禁用触摸移动

json - 如何从SQLITE UNION查询中获取单个JSON对象?

javascript - window.close() 和 beforeunload 事件