gpt4 book ai didi

javascript - 如何根据 jQuery 中的复选框选择向表添加和删除

转载 作者:行者123 更新时间:2023-12-02 23:41:50 24 4
gpt4 key购买 nike

我正在尝试创建一个用户权限表,该表将根据复选框中的选择显示分配用户的权限类型。

我尝试了几种我知道的方法并进行了搜索,但我似乎每次都陷入困境。我从这个答案中得到了类似的代码,jQuery append and remove values from checkbox to textarea ,有效。但当我尝试在工作中实现它时,它似乎不起作用。

<table id="permissionsTable">
<thead>
<th>Name</th>
<th>Slug</th>
<th>Description</th>
</thead>
<tbody id="tableBody">

</tbody>
</table>

<div id="alloptions">
<ul>
<li>
<input type="checkbox" name="option1" value="Play" />Play</li>
<li>
<input type="checkbox" name="option1" value="Create" />Create</li>
<li>
<input type="checkbox" name="option1" value="Delete" />Delete</li>
</ul>
</div>

这是 jQuery 代码:

var checkboxes = $("input[type='checkbox']");
var permsTable = $("#permissionsTable");
var valuer = [];


checkboxes.on('change', function() {
var values = checkboxes.filter(':checked').map(function(x, y) {
return y.value;
}).get();

checkboxes.filter(':checked').each(function(a, b) {

valuer.push($(this).val());

});


if (checkboxes.is(':checked')) {


permsTable.find('tbody').detach();
permsTable.append($('<tbody>'));


$.each(valuer, function(c, d) {
//alert(x + " : " + y);
var nameCol = d.substr(0, 1).toUpperCase() + d.substr(1) + " " + "Game";

var slugCol = d.toLowerCase() + "-" + "Game";
var descriptionCol = "Allow user to " + d.toUpperCase() + " a " + "Game";

$("#permissionsTable").find('tbody').append("<tr><td>" + nameCol + "</td><td>" + slugCol + "</td><td>" + descriptionCol + "</td></tr>");

});


} else {
permsTable.find('tbody').detach();
permsTable.append($('<tbody>'));
btnGeneratePermissions.css("display", "none");
}
});

我希望在选中复选框时将复选框的值添加到表行中;然后取消选中后删除该行。

最佳答案

使用 Template Literal ,这很简单

$("#alloptions").on("change", "[name=option1]", function(){
var mode = $(this).val();
const rowTemp = `<tr data-mode=${mode}>
<td><span style="text-transform: capitalize;">${mode} Game</span></td>
<td><span style="text-transform: lowercase;">${mode}</span>-Game</td>
<td>Allow user to <span style="text-transform: uppercase;">${mode}</span></td>
</tr>`;

if($(this).is(":checked")) {
$("#tableBody").append(rowTemp)
}else{
$("[data-mode='"+ mode +"']").remove();
}
})
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<table id="permissionsTable">
<thead>
<th>Name</th>
<th>Slug</th>
<th>Description</th>
</thead>
<tbody id="tableBody">

</tbody>
</table>

<div id="alloptions">
<ul>
<li>
<input type="checkbox" name="option1" value="Play" />Play</li>
<li>
<input type="checkbox" name="option1" value="Create" />Create</li>
<li>
<input type="checkbox" name="option1" value="Delete" />Delete</li>
</ul>
</div>

关于javascript - 如何根据 jQuery 中的复选框选择向表添加和删除 <tr>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56032097/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com