【发布时间】:2017-10-09 18:18:35
【问题描述】:
很不确定我以前是否理解,现在不理解,或者我不理解,现在我开始......或者我不理解,现在仍然不理解。
我正在构建一个允许用户预约的应用。
屏幕 1:选择位置和服务类型(选项列表、确认按钮并继续)
屏幕 2:选择可用的约会时间(表格、确认按钮并继续前进)
屏幕 3:输入姓名和联系信息(文本输入、确认按钮并继续)
屏幕 4:输入验证码(发短信给用户,按钮确认并继续)
屏幕 5:显示确认码
我正在重构,因为我意识到一切都在我的 ViewModel 中,并且不确定什么属于我的 Model 以及什么属于我的 ViewModel。我只是将 selectedLocation(用户从列表中选择的项目)放在模型中,但我需要它可以被视图访问,所以我这样做了:
self.selectedLocation = ko.pureComputed({
read: function() {
return self.model.selectedLocation();
},
write: function(value){
self.model.selectedLocation(value);
}
});
这看起来很疯狂。
这应该只在 ViewModel 中吗?我应该在模型中有一个 selectedLocation 变量,在 ViewModel 中有一个 currentSelectedLocation ,然后在用户确认位置和服务类型时更新 model.selectedLocation 吗?
每个单独的屏幕都应该有自己的视图模型吗?我正在使用单个 .html 文件并更新显示的内容,而不是逐页浏览。
我确定我没有包含某些重要信息,我很抱歉,很乐意回答任何问题。
任何帮助将不胜感激。
【问题讨论】:
-
模型和视图模型在淘汰赛中模糊。不要担心坚持某种模式——模式的存在是为了为你服务,而不是相反。我发现 UI 规定了什么是,什么不是,应该是 viewmodel-y。如果我得到一个 pojso 并且只需要在 UI 中显示它,它就是一个模型。如果它有一个需要交互式绑定的属性,我将它转换为一个 observable。不需要从集合中推送或弹出?这是一个数组。 UI必须响应?这是一个 observableArray。
标签: javascript mvvm knockout.js knockout-3.0