我正在尝试使用Boxing实现 MVVM 架构模式。我只是通过添加拳击类来完成它:
class Dynamic<T> {
typealias Listener = (T) -> Void
var listener: Listener?
func bind(listener: Listener?) {
self.listener = listener
}
func bindAndFire(listener: Listener?) {
self.listener = listener
listener?(value)
}
var value: T {
didSet {
listener?(value)
}
}
init(_ v: T) {
value = v
}}
Run Code Online (Sandbox Code Playgroud)
然后在 ViewController 中我引用了一个 ViewModel,这是我的 View Controller:
class SignUpViewController: UIViewController {
// UI Outlets
@IBOutlet weak var emailLoginTextField: FloatLabelTextField!
@IBOutlet weak var passwordLoginTextField: FloatLabelTextField!
var viewModel = AuthenticationViewModel()
override func viewDidLoad() {
super.viewDidLoad()
viewModel.user.email.bind{
self.emailLoginTextField.text = $0
}
}}
Run Code Online (Sandbox Code Playgroud)
这是我的视图模型:
class AuthenticationViewModel{
let defaults = UserDefaults.standard
let serviceManager = ServiceManager()
var user = User()
func signupUser(email : String?, password: String?){
let parameters : [String:String] = ["email":emailField, "password": password!, "system": "ios"]
serviceManager.initWithPOSTConnection(server: Utitlites.getServerName(), parameters: parameters, methodName: "/api/user/register", completion: { (responseData , errorMessage) -> Void in
let json = (responseData as AnyObject) as! JSON
print(json)
if ErrorHandling.handleErrorMessage(responseData: responseData).0 == true {
self.defaults.set("userId", forKey: json["user"]["id"].stringValue)
//self.userId.value = json["user"]["id"].stringValue
self.user = User(json: json)
}
})
}}
Run Code Online (Sandbox Code Playgroud)
这是我的模型:
class User{
var id = Dynamic("")
var name = Dynamic("")
var email = Dynamic("")
init(){
}
init(json: JSON){
id.value = json["user"]["id"].stringValue
email.value = json["user"]["email"].stringValue
}}
Run Code Online (Sandbox Code Playgroud)
我的问题是:
MVVM 架构明智,在 ViewController 中使用此行访问模型是否正确:
viewModel.user.email.bind{
self.emailLoginTextField.text = $0
}
Run Code Online (Sandbox Code Playgroud)
因为我现在可以看到 View 正在访问我认为不是 MVVM 代表的模型。我需要有人澄清
最好的做法去了解这个(IMO),并根据该raywanderlich视频的31:18是实际设置Model为私有,你的VC并不需要了解它在所有,只有ViewModel。
在此之后,对于设置干将Model在ViewModel这样的:
var id: Dynamic<String> = Dynamic("")
var name: Dynamic<String> = Dynamic("")
var email: Dynamic<String> = Dynamic("")
Run Code Online (Sandbox Code Playgroud)
然后,在你的ViewModel也,设置 User 对象有一个didSet通知程序,将相应地更新ViewModel的数据:
private var user = User() {
didSet {
id = user.id
name = user.name
email = user.email
}
}
Run Code Online (Sandbox Code Playgroud)
现在,您只能从而ViewModel不是Model直接访问这些属性:
viewModel.email.bind{
self.emailLoginTextField.text = $0
}
Run Code Online (Sandbox Code Playgroud)
哦,别忘了将 上的属性设置为Model常规字符串;)
| 归档时间: |
|
| 查看次数: |
5251 次 |
| 最近记录: |