- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
如果我的术语不正确,我深表歉意——这绝对不是我的专业领域。
我想制作一个 <select>
从 json 文件中列出,并将条目分组在 <optgroup>
中由一把 key 。我已经成功地列出了选择中的所有条目,但不知道如何循环遍历并将项目嵌套在它们的键下。
我的 JSON 看起来像这样:
[
{
"Type" : "Overdrive",
"Brand" : "Chase Bliss",
"Name" : "Brothers",
"Width" : 2.75,
"Height" : 4.77,
"Image" : "public/images/pedals/chasebliss-brothers.png"
}
]
下面是我如何渲染 <select>
:
window.RenderPedals = function(pedals){
for(var i in pedals) {
var $pedal = $("<option>"+ pedals[i].Brand + " " + pedals[i].Name +"</option>").attr('id', pedals[i].Name.toLowerCase().replace(/\s+/g, "-").replace(/'/g, ''));
$pedal.data('width', pedals[i].Width);
$pedal.data('height', pedals[i].Height);
$pedal.data('height', pedals[i].Height);
$pedal.data('image', pedals[i].Image);
$pedal.appendTo('.pedal-list');
}
}
我正在寻找的是这个标记:
<select>
<optgroup label="Chase Bliss">
<option data-width="..." data-height="..." data-image="...">Chase Bliss Brothers</option>
</optgroup>
</select>
谁能指出我正确的方向?
最佳答案
您可以使用对象解构获取当前对象的属性,无需 for..in
循环,创建一个 <optgroup>
带有 label
的元素属性设置为 "Brand"
, 追加 <option>
至 <optgroup>
, 追加 <optgroup>
至 <select>
.检查是否 <optgroup>
具有 label
的元素属性设置为 Brand
存在,如果 true
, 附加 <option>
那个<optgroup>
, 否则追加一个新的 <optgroup>
元素到 <select>
与 html
设置为新 <option>
元素。
var data = [{
"Type": "Overdrive",
"Brand": "Chase Bliss",
"Name": "Brothers",
"Width": 2.75,
"Height": 4.77,
"Image": "public/images/pedals/chasebliss-brothers.png"
}
, {
"Type": "Underdrive",
"Brand": "Bliss Chase",
"Name": "Sisters",
"Width": 5.72,
"Height": 7.74,
"Image": "public/images/pedals/chasebliss-sisters.png"
}
, {
"Type": "Throughdrive",
"Brand": "Bliss Chase",
"Name": "Cousins",
"Width": 2.75,
"Height": 4.74,
"Image": "public/images/pedals/chasebliss-cousins.png"
}
];
window.RenderPedals = function(pedals) {
var {Type, Brand, Name, Width, Height, Image} = pedals;
var option = $("<option>", {
text: `${Brand} ${Name}`,
id: Name.toLowerCase()
.replace(/(\s+)|(['"])/g, (m, p1, p2) => p1 ? "-" : ""),
data: {
width: Width,
height: Height,
image: Image
}
});
if ($("optgroup").is(`[label="${Brand}"]`)) {
$(`optgroup[label="${Brand}"]`).append(option);
} else {
$("<optgroup>", {
label: Brand,
html: option
}).appendTo(".pedal-list");
}
}
data.forEach(RenderPedals);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
</script>
<select class="pedal-list"></select>
关于javascript - 列出按键分组的数组内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42539350/
我对 JavaScript 上的 onkeypress 事件有疑问。 是否可以仅检测 Cntl 键或 Alt 键?此时,如果同时按下 Cntl 和 m,则 onkeypress 事件可以触发单击。是否
我想知道按键中允许使用什么样的字符。它是否也生成一个符号下划线(_)?我总是得到一个带有 - 字母的按键。 最佳答案 按键使用修改过的 Base64 字母表: -0123456789ABCDEFGHI
我有以下格式的(格式错误的DITA)XML: BLARG BLARG Definition BLARG2 BLARG2 Definition BLARG3 BLARG3 Definition
我有两个单独的对象数组,如果特定键值匹配,我需要将它们合并。分析数据后可能更有意义: 数组 1 let categories = [ { id: 5, slug: 'category-5',
由于我是新手,所以我的低效编码给大家带来了巨大的麻烦,对此我提前表示歉意。 我正在尝试在 HTML5 Canvas 上使用 Javascript 制作一个非常基本的游戏,但我似乎找不到一种简单的方法来
我试图找出将多维数组中的对象 id 属性映射到共享相同 id 的另一个数组中的对象值的最佳方法。 举个例子,我有一个像这样的genre_ids数组: 0: {id: 1, name: 'sci-fi'
我有一个游戏,当按下一个键时,您可以通过将子弹添加到 Controller 类来发射子弹。这是代码来自 KeyPressed(); else if (key == KeyEvent.VK_Q && !
我想比较两个字典的长度以及每个字典中每个键、值对的长度。如果在查找时没有匹配项,我还需要能够打印出来。 我当前的代码似乎传递了长度标准,但在尝试匹配元素时失败: assert_that(len(mod
我正在寻找一种跨平台(Win 和 MacOS)方法来检测 C# 中 OpenGL 应用程序的按键。 以下有效,但仅适用于字母数字字符。 protected override void OnKeyPre
我正在 try catch 按键事件(向上和向下翻页),但根本没有收到任何按键事件。这是相关代码:构造函数: private MainLayout() { imageView = new Im
$(el).bind('blur keypress', function(event){ if(event.type == 'keypress' && event.keyCode != 13) r
我有这段代码: while (SDL_PollEvent(&event)) { if (event.type == SDL_KEYDOWN) { switch(event.key.keys
我正在使用下面的代码: $(document).keypress(function (e) { if (e.which === 68 || e.which === 100) {
我正在用 html 和 javascript 制作游戏。只是为了澄清,这不是重复或任何东西。没有什么可以给我我需要的答案。另外,在解释之前,我想说我对按键监听器没有任何问题,我的游戏知道何时按下按键以
我正在尝试用 Javascript 制作游戏,但目前我已经陷入停滞。我正在尝试检测按键并检查它们是否不断按下以移动 Angular 色。这是我正在使用的代码: var THREE; var keys;
我得到了多维数组。我想从每个子数组中删除/取消设置索引为 1 的值。我的数组 $data。 Array ( [3463] => Array ( [0]
我正在设计一个基于网络的会计软件。例如,每当用户按 N 键时,我想打开“新会计凭证”。并在他/她按下 S 键时打开“设置”。 我看到了一些基于 JavaScript 和 jQuery 的脚本。但它们并
阅读此主题后: Keypress events stopped working outside of "input" elements in Meteor after update to 0.5.2
所以,当我按下按钮 1“1 PLAY/STOP”时,按钮变成绿色,当我再次按下它时它会去除颜色。 如果我按下 button2“2 PLAY/STOP”,同样的事情会发生。 如果两个按钮之一播放而我按下
非常直接的问题。 只想按一个键盘键。像输入一样,使用 pywin auto。我不想在任何应用程序窗口的上下文中按下它。 只是键盘键的原始按键,如 a 或 enter 或退格。 最佳答案 只需使用 #
我是一名优秀的程序员,十分优秀!