繁体   English   中英

从 select 获取自定义属性值

[英]Get custom attribute value from select

我正在尝试将 select 选项克隆到另一个 select 中。目前我可以做到,但现在原始选项包含自定义属性。 所以我的问题是如何访问自定义属性? 这就是我现在所拥有的:

var options = $('#sel1 option');
var arrayOptions = [];
for (var i = 0; i < options.length; i++) {
    var id = parseInt($(options[i]).val(), 10);
    var text = $(options[i]).text() || '[select a type]';
            
    arrayOptions.push('<option value="' + id + ' data-custom="' + options[i]["data-custom"] + '">' + text + '</option>');
    
}
console.log(arrayOptions);

<select id="sel1">
    <option value="1" data-custom="abc1">Hello 1</option>
    <option value="2" data-custom="abc2">Hello 2</option>
    <option value="3" data-custom="abc3">Hello 3</option>
</select>

现在 options[i]["data-custom"] 设置为 undefined 而不是 abc1、abc2 等。

是一个小提琴。

您可以使用dataset.custom

 var options = $('#sel1 option'); var arrayOptions = []; for (var i = 0; i < options.length; i++) { var id = parseInt($(options[i]).val(), 10); var text = $(options[i]).text() || '[select a type]'; arrayOptions.push('<option value="' + id + ' data-custom="' + options[i].dataset.custom + '">' + text + '</option>'); } $('#result').text(arrayOptions.join("\n"));
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <select id="sel1"> <option value="1" data-custom="abc1">Hello 1</option> <option value="2" data-custom="abc2">Hello 2</option> <option value="3" data-custom="abc3">Hello 3</option> </select> <pre id="result"></pre>

这边走

 const arrayOptions = [...document.querySelectorAll('#sel1 option')].map( opt => `<option value="${opt.id}" ` + `data-custom"${opt.dataset.custom}">` + `${opt.textContent}"</option>` ) console.log(arrayOptions);
 <select id="sel1"> <option value="1" data-custom="abc1">Hello 1</option> <option value="2" data-custom="abc2">Hello 2</option> <option value="3" data-custom="abc3">Hello 3</option> </select>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM