- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个用户界面,其中有一些复选框,我试图将其转换为对象数组。一个对象有 3 个键 Counter
,Name
和 IsActive
所有这些都是对象,将在数组中
当checkbox打开时isActive
应该是Y,我这里是根据我已经完成的任务得到一些好的方法
我做了什么
var Data = {
"Counter A": ["CounterA1.jpg", "CounterA2.jpg"],
"Counter B": ["CounterB1.jpg"],
"Counter C": ["CounterC1.jpg"]
}
var counter = {};
var name = {};
var flag = {};
for (var key in Data) {
var newCard = $(`<div>
<div class="card-header"></div>
<ul class="list-group list-group-flush">
</ul>
</div>`);
var ul_innerhtml = "";
$(".card-header", newCard).text(key);
Data[key].forEach(d => {
ul_innerhtml += '<li class="list-group-item">' + d + '<label class="switch "><input name="type" type="checkbox" class="success" value="' + d + '"><span class="slider round"> </span></label></li>'
counter = {
"Counter": key
} // geting name but it is only giving last counter i.e C
name = {
"Name": d
} // same fpor this
});
$(".list-group", newCard).append(ul_innerhtml);
$(".card").append(newCard.html());
}
$("#btn").click(function() {
console.log(counter) // printing counter C only
})
.switch {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
float: right;
}
/* Hide default HTML checkbox */
.switch input {
display: none;
}
/* The slider */
.slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #ccc;
-webkit-transition: .4s;
transition: .4s;
}
.slider:before {
position: absolute;
content: "";
height: 26px;
width: 26px;
left: 4px;
bottom: 4px;
background-color: white;
-webkit-transition: .4s;
transition: .4s;
}
input.success:checked+.slider {
background-color: #8bc34a;
}
input:checked+.slider:before {
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
/* Rounded sliders */
.slider.round {
border-radius: 34px;
}
.slider.round:before {
border-radius: 50%;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
<div class="container">
<div class="col-xs-12 col-sm-12 col-md-6 col-lg-6">
<div class="card" style="margin: 10px 0">
</div>
</div>
<button id="btn" class="btn btn-default commonButton" type="submit">
<i class="fa fa-search"></i> Go
</button>
</div>
点击开始我正在打印数据,但它只提供了一个数据
我想像这样创建对象
[ { "Counter": "Counter A", "Name": "CountA1.jpg", "IsActive":"Y" },
{ "Counter": "Counter A", "Name": "CountA2.jpg", "IsActive":"N" },
{ "Counter": "Counter B", "Name": "CountB1.jpg", "IsActive":"Y" },
{ "Counter": "Counter C", "Name": "CountC1.jpg", "IsActive":"Y" }]
因为我以后的工作才需要这个结构
最佳答案
因为您可以在渲染后动态设置复选框 的值。更好的方法是迭代生成的 DOM 以获取实时值。希望这会有所帮助。
var Data = {
"Counter A": ["CounterA1.jpg", "CounterA2.jpg"],
"Counter B": ["CounterB1.jpg"],
"Counter C": ["CounterC1.jpg"]
}
var counters = [];
var name = {};
var flag = {};
for (var key in Data) {
var newCard = $(`<div>
<div class="card-header"></div>
<ul class="list-group list-group-flush">
</ul>
</div>`);
var ul_innerhtml = "";
$(".card-header", newCard).text(key);
Data[key].forEach(d => {
ul_innerhtml += '<li class="list-group-item"><span>' + d + '</span><label class="switch "><input name="type" type="checkbox" class="success" value="' + d + '"><span class="slider round"> </span></label></li>'
});
$(".list-group", newCard).append(ul_innerhtml);
$(".card").append(newCard.html());
}
$("#btn").click(function() {
$('.card .list-group').each((i, listGroup) => {
$listGroup = $(listGroup);
$listGroup.find('li').each((j, list) => {
let counter = {
"Counter": $listGroup.prev().text()
}
$list = $(list);
counter.Name = $list.find('span').text();
counter.IsActive = $list.find('input').is(":checked") ? 'Y' : 'N';
counters.push(counter)
})
});
console.log(counters);
})
.switch {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
float: right;
}
/* Hide default HTML checkbox */
.switch input {
display: none;
}
/* The slider */
.slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #ccc;
-webkit-transition: .4s;
transition: .4s;
}
.slider:before {
position: absolute;
content: "";
height: 26px;
width: 26px;
left: 4px;
bottom: 4px;
background-color: white;
-webkit-transition: .4s;
transition: .4s;
}
input.success:checked+.slider {
background-color: #8bc34a;
}
input:checked+.slider:before {
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
/* Rounded sliders */
.slider.round {
border-radius: 34px;
}
.slider.round:before {
border-radius: 50%;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
<div class="container">
<div class="col-xs-12 col-sm-12 col-md-6 col-lg-6">
<div class="card" style="margin: 10px 0">
</div>
</div>
<button id="btn" class="btn btn-default commonButton" type="submit">
<i class="fa fa-search"></i> Go
</button>
</div>
关于javascript - 如何从 UI 创建所需数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56543148/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!