我是MVC设计模式的新手。我创建了“ DataModel”,它将使用委托和包含所有数据的“ DataModelItem”进行API调用,创建数据并将数据返回到ViewController。 如何在“ requestData”函数中调用DataModel初始化函数。这是我的代码:
protocol DataModelDelegate:class {
func didRecieveDataUpdata(data:[DataModelItem])
func didFailUpdateWithError(error:Error)
}
class DataModel: NSObject {
weak var delegate : DataModelDelegate?
func requestData() {
}
private func setDataWithResponse(response:[AnyObject]){
var data = [DataModelItem]()
for item in response{
if let tableViewModel = DataModelItem(data: item as? [String : String]){
data.append(tableViewModel)
}
}
delegate?.didRecieveDataUpdata(data: data)
}
}
对于DataModelItem:
class DataModelItem{
var name:String?
var id:String?
init?(data:[String:String]?) {
if let data = data, let serviceName = data["name"] , let serviceId = data["id"] {
self.name = serviceName
self.id = serviceId
}
else{
return nil
}
}
}
控制器:
class ViewController: UIViewController {
private let dataSource = DataModel()
override func viewDidLoad() {
super.viewDidLoad()
dataSource.delegate = self
}
override func viewWillAppear(_ animated: Bool) {
dataSource.requestData()
}
}
extension ViewController : DataModelDelegate{
func didRecieveDataUpdata(data: [DataModelItem]) {
print(data)
}
func didFailUpdateWithError(error: Error) {
print("error: \(error.localizedDescription)")
}
}
答案 0 :(得分:3)
如何在Swift中实现简单的MVC设计模式?
作为一个通用的答案,在iOS开发中,您已经在隐式执行此操作!处理情节提要暗含 view 层,并通过创建 view controller <来控制其工作方式以及它们如何与 model 连接的逻辑。 / em>,这是默认流程。
对于您的情况,让我们澄清一点:根据标准MVC,默认情况下,用于调用api的负责层应该是-逻辑上-视图控制器。但是,出于模块化,可重用性和避免创建大型视图控制器的目的,我们可以遵循您模仿的方法,这并不意味着它具有模型责任,我们可以将其视为辅助层(例如MVC-N) ),这意味着(根据您的代码)DataModel
是不是模型,其是一个“网络”层,而DataModelItem
是实际模型。
如何在“ requestData”函数中调用DataModel初始化函数
在我看来,它没有出现。相反,您需要的是DataModel
中的一个实例,因此您可以调用所需的方法。
在视图控制器中:
let object = DataModel()
object.delegate = self // if you want to handle it in the view controller itself
object.requestData()
答案 1 :(得分:0)
我只是在这里分享我的答案,而且我正在使用一个编码。它将对任何人都有用:
模型:
import Foundation
struct DataModelItem: Codable{
struct Result : Codable {
let icon : String?
let name : String?
let rating : Float?
let userRatingsTotal : Int?
let vicinity : String?
enum CodingKeys: String, CodingKey {
case icon = "icon"
case name = "name"
case rating = "rating"
case userRatingsTotal = "user_ratings_total"
case vicinity = "vicinity"
}
}
let results : [Result]?
}
网络层:
import UIKit
protocol DataModelDelegate:class {
func didRecieveDataUpdata(data:[String])
func didFailUpdateWithError(error:Error)
}
class DataModel: NSObject {
weak var delegate : DataModelDelegate?
var theatreNameArray = [String]()
var theatreVicinityArray = [String]()
var theatreiconArray = [String]()
func requestData() {
Service.sharedInstance.getClassList { (response, error) in
if error != nil {
self.delegate?.didFailUpdateWithError(error: error!)
} else if let response = response{
self.setDataWithResponse(response: response as [DataModelItem])
}
}
}
private func setDataWithResponse(response:[DataModelItem]){
for i in response[0].results!{
self.theatreNameArray.append(i.name!)
self.theatreVicinityArray.append(i.vicinity!)
self.theatreiconArray.append(i.icon!)
}
delegate?.didRecieveDataUpdata(data: theatreNameArray)
print("TheatreName------------------------->\(self.theatreNameArray)")
print("TheatreVicinity------------------------->\(self.theatreVicinityArray)")
print("Theatreicon------------------------->\(self.theatreiconArray)")
}
}
控制器:
class ViewController: UIViewController {
private let dataSource = DataModel()
override func viewDidLoad() {
super.viewDidLoad()
dataSource.delegate = self
}
override func viewWillAppear(_ animated: Bool) {
dataSource.requestData()
}
}
extension ViewController : DataModelDelegate{
func didRecieveDataUpdata(data: [DataModelItem]) {
print(data)
}
func didFailUpdateWithError(error: Error) {
print("error: \(error.localizedDescription)")
}
}
APIManager :
class Service : NSObject{
static let sharedInstance = Service()
func getClassList(completion: (([DataModelItem]?, NSError?) -> Void)?) {
guard let gitUrl = URL(string: "") else { return }
URLSession.shared.dataTask(with: gitUrl) { (data, response
, error) in
guard let data = data else { return }
do {
let decoder = JSONDecoder()
let gitData = try decoder.decode(DataModelItem.self, from: data)
completion!([gitData],nil)
} catch let err {
print("Err", err)
completion!(nil,err as NSError)
}
}.resume()
}
}
答案 2 :(得分:-1)
我建议为DataModel使用单例实例,因为这是一个类,您将从应用程序的许多方面调用它。 您可以在以下位置查阅其文档: Managing Shared resources using singleton 这样,您就不需要在每次需要访问数据时都初始化此类实例。