- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 knockout 实现的 n 级复选框树,其中父级复选框的选择应该选择它的子级(而不是相反)并且一旦提交数据,所选元素的 id 应该转换为 JSON 以发送到服务器。
我不知道如何处理单向复选框关系,也不知道如何以这种方式过滤我的最终 json:
如果选择了一个父项(因为这意味着它的所有子项也被选中)不在 json 中发送其子项 ID
如何在仅选择一个或几个 child 时不发送 parent ID。
列表项的模型是:
marketingListsItem = function (data, parent) {
var self = this;
self.Name = ko.observable(data.Name);
self.Selected = ko.observable(data.Selected);
self.Parent = ko.observable(parent);
self.Children = ko.observableArray([]);
self.Id = ko.observable(data.Id);
self.DateAdded = ko.observable(new Date(data.DateAdded));
self.DateModified = ko.observable(data.DateModified);
if (data.Children) {
ko.utils.arrayForEach(data.Children, function (child) {
self.Children.push(new marketingListsItem(child, this));
}.bind(this));
};
}
这是 View 模型部分:
marketingListsViewModel = {
marketingLists: mapping.fromJS([]),
originatorConnectionName: ko.observable(''),
selectedMarketingListIds: ko.observableArray([])
},
init = function (connectionId, connectionName) {
marketingListsViewModel.originatorConnectionName(connectionName);
marketingListsViewModel.getFieldMapping = function () {
require(['mods/fieldmapping'], function (fieldmapping) {
fieldmapping.init(connectionId, connectionName);
});
};
// Here I only managed to filter the parent level selections
marketingListsViewModel.selectedLists = ko.computed(function () {
return ko.utils.arrayFilter(marketingListsViewModel.marketingLists(), function (item) {
return item.Selected() == true;
});
});
marketingListsViewModel.saveMarketingListChanges = function () {
// Which I can filter my JSON to include them but the children are missing
var latestMarketingListChanges = ko.toJSON(marketingListsViewModel.selectedLists, ["Id"]);
console.log(latestMarketingListChanges);
amplify.request("updateExistingMarketingLists", { cid: connectionId, ResponseEntity: { "id": connectionId, "selectedMarketListIds": latestMarketingListChanges } },
function (data) {
console.log(data);
});
}
amplify.request("getExistingMarketingLists", { cid: connectionId }, function (data) {
showMarketingLists();
mapping.fromJS(data.ResponseEntity, dataMappingOptions, marketingListsViewModel.marketingLists);
ko.applyBindings(marketingListsViewModel, $('#marketingLists')[0]);
});
};
最后是 View :
<div id="marketingListsContainer">
<ul data-bind="template: {name: 'itemTmpl' , foreach: marketingLists}"></ul>
<script id="itemTmpl" type="text/html">
<li>
<label><input type="checkbox" data-bind="checked: Selected" /><span data-bind='text: Name'></span></label>
<ul data-bind="template: { name: 'itemTmpl', foreach: Children }" class="childList"></ul>
</script>
</div>
<a class="s_button modalClose right" href="#"><span data-bind="click: saveMarketingListChanges">Save and close</span></a><br>
最佳答案
感谢您的回答。问题是,如果您的解决方案现在已经通过服务器的数据检查了父项,那么它的子项的检查值不会发生变化。
我已将以下内容添加到模型中以解决此问题:
self.sync = ko.computed(function () {
return self.Selected.valueHasMutated();
});
对于那些稍后会找到这篇文章并且可能想看看最终结果是什么的人:
define('mods/marketinglists', ["knockout", "libs/knockout.mapping", "libs/knockout.validation", "datacontext", "mods/campaigner", "text!templates/marketinglists.html", "text!styles/marketinglists.css"],
function (ko, mapping, validation, datacontext, campaigner, html, css) {
'use strict';
var
marketingListsItem = function (data, parent) {
var self = this;
self.Name = ko.observable(data.Name);
self.Selected = ko.observable(data.Selected);
self.Parent = ko.observable(parent);
self.Children = ko.observableArray([]);
self.Id = ko.observable(data.Id);
self.DateAdded = ko.observable(new Date(data.DateAdded));
self.DateModified = ko.observable(data.DateModified);
// If node contains children define each one as a marketingListItem in itself
// and bind it to the the model
if (data.Children) {
ko.utils.arrayForEach(data.Children, function (child) {
self.Children.push(new marketingListsItem(child, this));
}.bind(this));
};
// Watch for value changes in parent and check children
// if the parent was checked
self.Selected.subscribe(function (newValue) {
if (newValue === true) {
for (var i = 0; i < self.Children().length; i++) {
self.Children()[i].Selected(true);
}
}
else {
if (self.Parent() != null) { self.Parent().Selected(false); }
}
});
// Make sure subscribers have been notified when needed
self.sync = ko.computed(function () {
return self.Selected.valueHasMutated();
});
},
dataMappingOptions = {
key: function (data) {
return data.Id;
},
create: function (options) {
return new marketingListsItem(options.data, null);
}
},
showMarketingLists = function () {
campaigner.addStylesToHead(css);
campaigner.addModalWindow(html, {
windowSource: "inline",
width: 700,
height: '340'
});
},
marketingListsViewModel = {},
init = function (connectionId, connectionName) {
// Define marketingLists as an observable array from JS object
marketingListsViewModel.marketingLists = mapping.fromJS([]);
marketingListsViewModel.originatorConnectionName = ko.observable('');
// Set the name for the marketing list
marketingListsViewModel.originatorConnectionName(connectionName);
marketingListsViewModel.getFieldMapping = function () {
require(['mods/fieldmapping'], function (fieldmapping) {
fieldmapping.init(connectionId, connectionName);
});
};
marketingListsViewModel.selectedLists = ko.computed(function () {
var selectedItems = [];
ko.utils.arrayFilter(
marketingListsViewModel.marketingLists(),
function (item) {
// If a parent a selected its being collected
if (item.Selected() == true) selectedItems.push(item);
else {
// If a child is slected it is collected
ko.utils.arrayForEach(item.Children(), function (child) {
if (child.Selected()) selectedItems.push(child);
else {
ko.utils.arrayForEach(child.Children(),
// Finally if children's child is selected its collected
function (childChildren) {
if (childChildren.Selected())
selectedItems.push(childChildren);
});
}
})
}
});
return selectedItems;
});
marketingListsViewModel.saveMarketingListChanges = function () {
// Pick only the selected elements and parse only the Id
var latestMarketingListChanges = ko.toJSON
(marketingListsViewModel.selectedLists,
["Id"]);
console.log(latestMarketingListChanges);
// Send the latest marketing lists changes Ids to the server
amplify.request("updateExistingMarketingLists",
{
cid: connectionId,
ResponseEntity:
{
"id": connectionId,
"selectedMarketListIds": latestMarketingListChanges
}
},
function (data) {
console.log(data);
});
}
amplify.request("getExistingMarketingLists", { cid: connectionId },
function (data) {
showMarketingLists();
mapping.fromJS(
data.ResponseEntity,
dataMappingOptions,
marketingListsViewModel.marketingLists);
ko.applyBindings(marketingListsViewModel, $('#marketingLists')[0]);
});
};
return {
init: init,
marketingListsViewModel: marketingListsViewModel,
html: html,
css: css
}
});
有了这个观点:
<div id="marketingListsContainer">
<ul data-bind="template: {name: 'itemTmpl' , foreach: marketingLists}"></ul>
<script id="itemTmpl" type="text/html">
<li>
<!-- ko if: $data.Parent -->
(my parent is: <span data-bind="text: $data.Parent().Name"></span>)
<!-- /ko -->
<label><input type="checkbox" data-bind="checked: Selected" /><span data-bind='text: Name'></span></label>
<ul data-bind="template: { name: 'itemTmpl', foreach: Children }" class="childList"></ul>
</script>
</div>
<a class="s_button modalClose right" href="#"><span data-bind="click: saveMarketingListChanges">Save and close</span></a><br>
关于javascript - n 级深度复选框树行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14857620/
我想创建一个基于 jQuery 的非常简单的 html 编辑器(不是所见即所得)。 我的问题是如何制作 textarea或 div可能 在上面写一些文字 然后样式即标签(例如 some stuff 将
根据文档 isset 条款“测试此项目中是否已设置给定属性”。我不明白设置属性时 isset 返回 true 还是 false 在下面的代码片段中,当 env.JAVA_HOME 未设置时,java.
我正在尝试取消映射 o这是执行 :only 的默认命令( :help :only ),所以我尝试的第一件事是: nmap o 这种作品,除非我按 ,等待超过timeoutlen ms 然后按 o
我有以下型号: class MetaData(models.Model): created_at = models.DateTimeField(auto_now_add=True, auto_
下面列出了两行代码。两者对日期和时间的期望相同,但只有一个有效。我正在使用 R 3.1。 以下不起作用: DateTime2=strftime("08/13/2010 05:26:24.350", f
我有一个关于 C 代码的问题。 #include void foo(void){ int a; printf("%d\n",a); } void bar(void){
如果文件大小 > 8k,为什么读取的最后一个字节 = 0? private static final int GAP_SIZE = 8 * 1024; public static void main(
我有一个命令 Get-Testdata从不同来源检索测试数据并将这些数据存储到 PSObject以不同的值作为属性。然后将对象总数存储为数组,以便于操作、排序、计算等。 我的问题是我希望能够将这些数据
我正在使用 epoll 将大消息写入使用 HTTP 协议(protocol)的服务器。 fds 都设置为非阻塞,我正在使用边缘触发事件。我知道对于 EPOLLIN,我需要循环读取 fd,直到返回 EA
这对我来说听起来很奇怪: $test_1 = 'string'; $test_2 = '0'; var_dump(intval($test_1)); // Output: int 0 var_dump
这个问题在这里已经有了答案: Java: Integer equals vs. == (7 个回答) 7年前关闭。 请您解释以下行为。 public class EqAndRef { publ
Drupal 的行为到底是什么? 它为模块开发人员提供什么类型的服务层? 它映射到 jQuery.ready 的关系类型是什么? 最佳答案 长版:Drupal.behaviors 不仅仅是 jQuer
以下代码: dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{ for (int i=0
人们可以将项目添加到数据库中。我让他们选择在此时添加它,或手动选择日期。 因此我得到了这个 HTML 结构。 (请注意,我将日期和时间选择器妥协为只有一行文本) Selec
创建了一个数据框: simpleDF is.na(simpleDF$vals) [1] TRUE TRUE FALSE > is.nan(simpleDF$vals) [1] FALSE TRU
我有一个大的 docker 镜像 A,我创建了一个新的 Dockerfile FROM A RUN rm /big-folder 我尝试使用以下方法构建图像: docker build --squas
我想知道以下情况下 JVM 的行为是什么: JVM 最小堆大小 = 500MB JVM 最大堆大小 = 2GB 操作系统有 1GB 内存 JVM启动后,程序运行一段时间后,使用内存超过1GB。我想知道
我们正在使用 spikeearrest 策略,但我们不了解其工作原理。峰值逮捕配置如下: 5pm 阅读文档,我们了解到,如果我们在一分钟内调用此流超过 5 次,则该策略将在第 5 次之后
我正在使用 cURL 发送 POST 请求: curl http://tarvos.local:8080/partial_Users/2 -d '{currentPage : 1, firstID :
我的表中有 6442670 条记录,我正在使用以下命令获取它们jdbctemplate 使用行号一次 1000000 个。以下是查询 select * from (select rowNum rn
我是一名优秀的程序员,十分优秀!