- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在 textarea 中填充一组值,如果复选框名称是 category 被选中,它将输出一个换行符,然后如果复选框名称是 product 则缩进。如果未选中父产品或类别,则删除详细信息。
$(document).ready(function() {
var elems = $('input:checkbox');
elems.on('change', function() {
$('#list').val(
elems.filter(':checked').map(function() {
return this.value;
}).get().join("\n\t")
);
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form>
<table border="1">
<tr><td>Category</td>
<td>Name</td>
<td>Details</td>
</tr>
<tr>
<td rowspan="3"><label><input type="checkbox" value="Category 1" name="category" /> Category 1</label></td>
<td><label><input type="checkbox" value="ProductName A" name="product" /> ProductName A</label></td>
<td><label><input type="checkbox" value="ProductDetail A-1" name="detail" /> ProductDetail A-1</label></td>
</tr>
<tr><td rowspan="2"><label><input type="checkbox" value="ProductName B" name="product" /> ProductName B</label></td>
<td><label><input type="checkbox" value="ProductDetail B-1" name="detail" /> ProductDetail B-1</label></td>
</tr>
<tr><td><label><input type="checkbox" value="ProductDetail B-2" name="detail" /> ProductDetail B-2</label></td></tr>
<tr>
<td rowspan="3"><label><input type="checkbox" value="Category 2" name="category" /> Category 2</label></td>
<td><label><input type="checkbox" value="ProductName A" name="product" /> ProductName A</label></td>
<td><label><input type="checkbox" value="ProductDetail A-1" name="detail" /> ProductDetail A-1</label></td>
</tr>
<tr><td rowspan="2"><label><input type="checkbox" value="ProductName B" name="product" /> ProductName B</label></td>
<td><label><input type="checkbox" value="ProductDetail B-1" name="detail" /> ProductDetail B-1</label></td>
</tr>
<tr><td><label><input type="checkbox" value="ProductDetail B-2" name="detail" /> ProductDetail B-2</label></td></tr>
</table>
<textarea id="list" rows="10" cols="45" ></textarea>
</form>
我当前的脚本返回一组换行项:
Category 1
ProductName A
ProductDetail A-1
ProductName B
ProductDetail B-1
ProductDetail B-2
Category 2
ProductName A
ProductDetail A-1
ProductName B
ProductDetail B-1
ProductDetail B-2
是否可以像预期的那样查看?或者你有什么想法来满足这个输出吗?
Category 1
ProductName A
ProductDetail A-1
ProductName B
ProductDetail B-1
ProductDetail B-2
Category 2
ProductName A
ProductDetail A-1
ProductName B
ProductDetail B-1
ProductDetail B-2
最佳答案
试试这个:
$(document).ready(function() {
var elem = $('input:checkbox');
elem.on('change', function() {
$('#list').val(
elem.filter(':checked').map(function() {
if(this.name == 'product') {
return "\t" + this.value
}
if(this.name == 'detail') {
return "\t\t" + this.value
}
return this.value;
}).get().join("\n")
);
});
});
我测试了它,它似乎有效;)
为了能够检查父元素是否被选中,您需要在输入中包含有关您的父元素的信息:例如,使用 data-parent 属性,因此您将拥有:html
<tr>
<td rowspan="3">
<label><input type="checkbox" value="Category 1" name="category" /> Category 1</label>
</td>
<td>
<label><input type="checkbox" value="ProductName A" name="product" data-parent="Category 1"/> ProductName A</label>
</td>
<td>
<label><input type="checkbox" value="ProductDetail A-1" name="detail" data-parent="ProductName A" /> ProductDetail A-1</label>
</td>
</tr>
<tr>
<td rowspan="2">
<label><input type="checkbox" value="ProductName B" name="product" data-parent="Category 1"/> ProductName B</label>
</td>
<td>
<label><input type="checkbox" value="ProductDetail B-1" name="detail" data-parent="ProductName B"/> ProductDetail B-1</label>
</td>
</tr>
<tr>
<td>
<label><input type="checkbox" value="ProductDetail B-2" name="detail" data-parent="ProductName B"/> ProductDetail B-2</label>
</td>
</tr>
JS
function checkParent(type, value) {
return $('input:checkbox[name="' + type + '"][value="' + value + '"]:checked').length;
}
$(document).ready(function() {
var elem = $('input:checkbox');
var parent;
elem.on('change', function() {
$('#list').val(
elem.filter(':checked').map(function() {
if(this.name == 'product') {
// check for parent category
parent = $(this).data('parent');
if(checkParent("category", parent)) {
return "\t" + this.value;
} else {
return '';
}
}
if(this.name == 'detail') {
parent = $(this).data('parent');
category = $('input:checkbox[name="product"][value="' + parent + '"]').data('parent');
if(checkParent("product", parent) && checkParent("category", category)) {
return "\t\t" + this.value;
} else {
return '';
}
}
return this.value;
}).get().join("\n").replace("\n\n", "\n")
);
});
});
如果是产品,我们会检查父类别,如果是详情,我们会检查产品和类别。
需要最后一个replace 来防止出现空行。
关于javascript - 如何加入和缩进选中的项目取决于 jquery 中的名称/ID?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41258117/
在具有资源的Grails 2.3X的旧世界中,可以按特定顺序定义实际资源,即dependsOn 我一直在寻找 Assets 说明: https://github.com/bertramdev/asse
嗨,我正处于一个场景中,我正在考虑拥有多个模块,并让模块依赖于其他模块。 假设我们正在构建一个业务系统,其中一部分是进销存,并且我们在不同的分支机构都有客户。 因此,一个行业可能希望使用某些工具并以自
#include int main(void) { char ch; int count; while((ch=getchar())!=EOF){ if(ch
我想使用基于 gcc 开关的 #if 指令交叉编译特定的 32 位和 64 位代码。 我可以使用 GCC 设置的任何宏来代替使用 -D 开关设置宏吗? 我能否以某种方式获取 gcc 命令选项中使用的开
这是对我之前的 question 的更复杂的后续操作.答案是使用矩阵,但这不适用于具有不同模式值的数据框。 我想将不同大小的数据框与字符和整数列组合在一起,并根据多个条件计算它们的总和。 状况 仅针对
希望获得有关 dependsOn 的一些指导和解释。 我在模板中看到有两种在模板中提供依赖项的方法。 一种方法是提供resourceId,另一种方法是使用concat提供字符串值。我试图理解两者之间的
我编写了一些包含一些额外函数的包,用于处理反射(reflect)我喜欢使用它们的方式的常见类型(例如,我更喜欢将 Bson 文档视为 map ,而不是字段列表)。我将这些包保存在本地源目录中,而不是在
我有类似于这样的 View 模型: public class MyDialogViewModel { public MyButtonViewModel[] Buttons{ get; }
我只使用一项 Activity ,很少使用碎片。我只想在启动画面上隐藏工具栏。我这样写: class MainActivity : AppCompatActivity() { lateinit var
在我的 M-V-VM 应用程序中,我必须显示用户的头像。图像在 ViewModel 对象的 ImageSource 类型的属性中提供。这就是我目前拥有的: 但是,有些用户可能没有配置头像,所以Use
如何在 setTimeout 后调用带有 addEventListener 的函数?这是代码示例: xyz = setTimeout(function () { [...blabla func
我正在学习 Spring 并进行一些研发。 我尝试了“依赖”概念。 sparsh --> 25 3
我有一个 Rust 库,它基本上是一些 C 源代码和一个 bindgen 包装器。它有一个进入 C 源目录的 build.rs 脚本,运行 make,并将 .a 静态库复制到 $OUT_DIR。当我运
我使用 middleman用于开发网站并希望使用 .yml 文件将标记与内容分开。那么问题来了: 有没有办法根据某个 css 类更改 ruby 数据路径? 例如,我只想在父标签中有一个 css 类
此代码在转到 URL 的目标之前淡出每个页面。但是,在某些情况下,用户不会转到新页面,而是转到浏览器中的 PDF,或者打开默认邮件应用程序。在 Safari 上,如果您转到外部站点 (www.twit
在 Microsoft Solver Foundation 中,我想知道是否可以添加一个值取决于决策值的参数。 即我想要 TSP 模型的一些东西,但它还应该考虑从一个点到另一个点的流量。请注意:流量取
我正在尝试根据来自同一张表的 cid 获取新表中成人和 child 的总和。 餐 table 销售 +-----------+------------+---------------+ | cid
我有这个 .htaccess 文件,但我希望它只在我在实时站点上时才这样做。 有什么办法可以: // if server_name looks like example.com to this //
我对编程很陌生,现在一直在寻找解决方案,但由于我不确定我到底在寻找什么,所以我决定问你。 根据 Firebase 上的数据,我希望构建一个包含文本和图像的按钮。 例如,我有一个数据库,包括: User
我正在网上商店运行一个表单,如下所示: 按下提交按钮后,我根据从 $_POST 获得的信息在 php 中运行一个简单的错误检查。我有一个名为 $errors 的数组,如果我
我是一名优秀的程序员,十分优秀!