遍历深度嵌套的对象以生成HTML的optgroup/options
创始人
2024-12-04 03:30:42
0

以下是一个示例代码,用于遍历深度嵌套的对象,并生成HTML的optgroup/options:

function generateOptions(data, level = 0) {
  let html = '';

  // 遍历对象的键值对
  for (let key in data) {
    const value = data[key];

    // 根据嵌套层级添加缩进
    const indent = ' '.repeat(level * 4);

    // 如果值是一个对象,则生成optgroup标签,并递归调用generateOptions
    if (typeof value === 'object') {
      html += `${generateOptions(value, level + 1)}`;
    } 
    // 如果值是一个字符串或数字,则生成option标签
    else {
      html += ``;
    }
  }

  return html;
}

// 示例数据
const data = {
  "选项1": "值1",
  "选项2": {
    "子选项1": "值2",
    "子选项2": "值3",
  },
  "选项3": {
    "子选项3": {
      "子子选项1": "值4",
      "子子选项2": "值5",
    },
    "子选项4": "值6",
  },
};

// 生成HTML
const html = generateOptions(data);

// 将HTML插入到页面中
document.getElementById('select').innerHTML = html;

在上面的代码中,我们定义了一个名为generateOptions的递归函数,它接收一个嵌套对象作为输入并返回生成的HTML字符串。我们在函数中遍历对象的键值对,并根据值的类型生成optgroupoption标签。如果值是一个对象,则递归调用generateOptions函数以生成嵌套的optgroup标签。如果值是一个字符串或数字,则生成一个option标签。通过递归调用generateOptions函数,我们可以处理任意深度的嵌套对象。

在示例中,我们定义了一个名为data的示例数据对象,并调用generateOptions函数生成HTML字符串。最后,我们将生成的HTML字符串插入到id为select的元素中,这是一个select标签,用于显示生成的optgroupoption标签。

相关内容

热门资讯

十分钟了解!传送屋高防版辅助,... 十分钟了解!传送屋高防版辅助,八闽十三水好牌,透牌教程(有挂神器)运传送屋高防版辅助辅助工具,进入游...
两分钟了解!广东雀神麻雀辅助器... 两分钟了解!广东雀神麻雀辅助器免费测试,边锋保皇辅助工具,可靠技巧(有挂揭秘)亲,关键说明,广东雀神...
四分钟了解!菠萝德州辅助,鱼乐... 四分钟了解!菠萝德州辅助,鱼乐达人ios辅助器,技巧教程(有挂细节)1、鱼乐达人ios辅助器系统规律...
2分钟了解!江西中至辅助器,宝... 2分钟了解!江西中至辅助器,宝宝浙江游戏辅助有人在用吗,攻略教程(有挂脚本)宝宝浙江游戏辅助有人在用...
1分钟了解!欢乐情怀软件使用方... 1分钟了解!欢乐情怀软件使用方法,闲逸斗地主有没有挂,透牌教程(有挂教程)一、欢乐情怀软件使用方法A...
三分钟了解!白金岛自创房有外 ... 三分钟了解!白金岛自创房有外 挂吗,闲逸游戏有辅助工具吗,揭秘教程(有挂解说)1、进入游戏-大厅左侧...
3分钟了解!新疆巴郎麻将打牌秘... 3分钟了解!新疆巴郎麻将打牌秘诀,潮友潮汕麻将木塞都是机器人,技巧教程(有挂技巧)1、超多福利:超高...
九分钟了解!钱柜手游可以开挂吗... 九分钟了解!钱柜手游可以开挂吗,大凉山生活号辅助器,解密教程(有挂规律)在进入大凉山生活号辅助器辅助...
三分钟了解!喜扣打筒子辅助器怎... 三分钟了解!喜扣打筒子辅助器怎么下载,多乐跑胡子如何提高胡牌率,详细教程(有挂解说);1、打开软件启...
十分钟了解!小松宿松麻将记牌器... 十分钟了解!小松宿松麻将记牌器,天天爱掼蛋辅助,介绍教程(有挂方法)1、打开软件启动之后找到中间准星...