仅从 ko.observableArray 发送更新的对象
Posted
技术标签:
【中文标题】仅从 ko.observableArray 发送更新的对象【英文标题】:Sending only the updated object from ko.observableArray 【发布时间】:2017-10-18 04:45:45 【问题描述】:如何仅发送可观察数组中的更新模型,而不是发送整个数组?
var student = function ()
this.studentId=0;
this.firstName=ko.obserable();
this.lastName=ko.obserable();
var course= function ()
this.courseId=0;
this.students=ko.obserableArray([]);
this.Name=ko.obserable();
现在我只想从课程中获取信息已更新的特定学生。假设当我们添加一个新班级时,我们可以在旅途中动态地向其中添加新学生。假设您必须在添加新学生之前验证前一个学生。当我得到那个特定的学生时,我想将该学生信息发送回服务器。
谢谢。
【问题讨论】:
在添加新学生之前验证之前的学生是什么意思? 我有一个(添加更多)按钮,可以将新学生添加到 DOM 和数据库中。验证意味着如果用户输入了学生的有效信息,那么他可以将另一个学生添加到该课程中。 我发布了关于如何获取已修改学生列表的答案。 【参考方案1】:如果我理解您的任务,您可以使用“arrayChange”事件类型来获取完全更改(添加/删除)的项目:
sourceArray = ko.observableArray();
sourceArray.subscribe(function (changes)
changes.forEach(function(arrayChange)
if(arrayChange.status === 'added')
// some code on add
else if(arrayChange.status === 'deleted')
// some code on delete
);
, null, "arrayChange");
【讨论】:
【参考方案2】:如果您想获取已修改的学生列表,您可以提供一个标志来标识学生对象中的对象是否已被修改。每当更新值时,使用.subscribe
修改该标志。然后使用ko.computed
或ko.pureComputed
获取该列表。
也应该是observable
。
var student = function (id, firstName, lastName)
var self = this;
self.hasChanged = ko.observable(false);
var modified = function()
self.hasChanged(true);
;
self.studentId = ko.observable(id);
self.firstName = ko.observable(firstName);
self.firstName.subscribe(modified);
self.lastName = ko.observable(lastName);
self.lastName.subscribe(modified);
var course= function ()
var self = this;
self.courseId = 0;
self.students = ko.observableArray([new student(1, "Cristiano", "Ronaldo"), new student(2, "Lionel", "Messi")]);
self.modifiedStudent = ko.computed(function()
return ko.utils.arrayFilter(self.students(), function(student)
return student.hasChanged();
);
, self);
self.Name = ko.observable("Programming 101");
$(document).ready(function ()
var myViewModel = new course();
ko.applyBindings(myViewModel);
);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
List of all students:
<div data-bind="foreach: students">
<div>
<span data-bind="text: studentId"></span>
<input type="text" data-bind="value: firstName" />
<input type="text" data-bind="value: lastName" />
</div>
</div>
<br/>
List of students which has been modified:
<div data-bind="foreach: modifiedStudent">
<div>
<span data-bind="text: studentId"></span>
<input type="text" data-bind="value: firstName" readonly />
<input type="text" data-bind="value: lastName" readonly />
</div>
</div>
【讨论】:
以上是关于仅从 ko.observableArray 发送更新的对象的主要内容,如果未能解决你的问题,请参考以下文章
为啥 ko.ObservableArray 中的替换值没有更新我的视图?
Knockoutjs递归地展开ko.observableArray
如何将 json 字符串转换为 ko.observableArray([]),他们得到一个错误数据未定义?