2

私のアプリでは、AlamofireObjectMapper を初めて使用しています。だから私はAPI応答データを1つのクラスにマッピングしてから、そのデータを使用したいと考えています。これが私のコードで、オブジェクトをどのようにマップするかです

    extension OrderListViewController
{
 func get_order_list()
  {


        let url = "\(OrderURL)get_New_order_byPharmacy"
        let param : [String : AnyObject] = [

            "pharmacyId" : "131"
        ]

        Alamofire.request(.GET, url, parameters: param, encoding: .URL).responseObject { (response:Response<OrderList, NSError>) in
            let OrderList = response.result.value
            print(OrderList!.Message)
        }

    }
}

ここにデータを保存するクラスがあります

    class OrderList: Mappable {
    var Message : String!
    var Status : Int!
    var result:[OrderResult]?



    required init?(_ map: Map){

    }

    func mapping(map: Map) {
        Message <- map["Message"]
        Status <- map["Status"]
        result <- map["Result"]

    }

}

今、私の OrderListViewController でこのデータを使用したいので、どうすればこれを使用できますか??

    class OrderListViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {

    @IBOutlet weak var table_OrderList: UITableView!


    override func viewDidLoad() {
        slideMenuController()?.addLeftBarButtonWithImage(UIImage(named: "ic_menu_black_24dp")!)
        slideMenuController()?.addRightBarButtonWithImage(UIImage(named: "ic_notifications_black_24dp")!)
        get_order_list()
    }


    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {

    }

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

        let cell : OrderList_Cell = tableView.dequeueReusableCellWithIdentifier("OrderList_Cell") as! OrderList_Cell



        return cell

    }

    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 20

    }
}

たとえば、テーブルビューのセル ラベルにメッセージ値を出力したいとします。どうすればOrderListからその値を取得できますか?

スラバに感謝します。解決策を教えてください。しかし、私のjson応答は私に配列を与えます。では、どうすればそれを管理できますか?numberofrowinSetcion は配列の数で返したいので、どうすればこれを行うことができますか。私の更新された質問をご覧ください。

ここに私のAPI応答があります。

    {
    "Status": 1,
    "Message": "records are available",
    "Result": [
        {
            "id": 30162,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-11T10:45:00.6779848",
            "created": "11 May 2016"
        },
        {
            "id": 30170,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-12T07:01:00.6968385",
            "created": "12 May 2016"
        },
        {
            "id": 30171,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-12T09:12:53.5538349",
            "created": "12 May 2016"
        },
        {
            "id": 30172,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-12T09:46:09.4329398",
            "created": "12 May 2016"
        },
        {
            "id": 30173,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-12T11:26:58.3211678",
            "created": "12 May 2016"
        },
        {
            "id": 30178,
            "status_id": 2,
            "status_type": "New Order",
            "created_date": "2016-05-16T07:34:19.9128517",
            "created": "16 May 2016"
        }
    ]
}
4

2 に答える 2

1

テーブルを埋めるために使用されるすべての受信情報を格納するには、コントローラーにローカル変数が必要です。そのようなことをする必要があります:

class OrderListViewController: ... {
    private var orderList: OrderList? // <- the local variable needed
    ...
}

extension OrderListViewController {
    func get_order_list() {
        ...
        Alamofire
            .request(...)
            .responseObject { (response:Response<OrderList, NSError>) in
                switch response.result {
                case .Success(let value):
                    self.orderList = value // <- fill the local variable with the loaded data
                    self.tableView.reloadData()
                case .Failure(let error):
                    // handle error
                }
            }
    }
    ...
}

extension OrderListViewController: UITableViewDataSource {
    ...
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell : OrderList_Cell = tableView.dequeueReusableCellWithIdentifier("OrderList_Cell") as! OrderList_Cell
        // I assume 'OrderList_Cell' class has outlet for status type named 'statusTypeLabel' and OrderResult.statusType is of type String
        if let orderList = orderList, orderResults = orderList.result {
            cell.statusTypeLabel.text = orderResults[indexPath.row].statusType // <- use of the locally stored data
        }

        return cell
    }

    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        if let orderList = orderList, orderResults = orderList.result {
            return orderResults.count
        } else {
            return 0
        }
    }
}

注: バックエンドから JSON で単一のオブジェクトを受け取る場合、コードは正しいはずです。バックエンドがオブジェクトの配列を送信する場合、配列を使用してローカル データ ( private var listOfOrderLists: [OrderList])を保存し、Alamofire.request(...).responseArray(...)代わりに使用する必要があります。しかし、ローカル変数に関する考え方は同じです。

于 2016-05-17T06:20:22.993 に答える
0
typealias FailureHandler = (error: AnyObject) -> Void
typealias SuccessHandler = (result: AnyObject)  -> Void 
class WebServiceManager: NSObject {

    class func getDataFromService(mehodName:String,success:(result:AnyObject)->(), apiError:(FailureHandler))
    {
         let url = "\(OrderURL)get_New_order_byPharmacy"
        let param : [String : AnyObject] = [

            "pharmacyId" : "131"
        ]

         alamoFireManager!.request(.GET, url)
            .responseJSON { response in
            print(response.response!)
                print(response.result)
                CommonFunctions.sharedInstance.deactivateLoader()
                switch response.result {
                case .Success(let JSON):
                    print("Success with JSON: \(JSON)")

                    guard let _ = JSON as? NSMutableArray else {
                        apiError(error: "")
                        return
                    }
                    let listOfItem:NSMutableArray = NSMutableArray()

                    for (_, element) in adsArray.enumerate() {
                        let adsItem = Mapper<OrderList>().map(element)
                    listOfItem.addObject(adsItem!)
                    }


                    success(result:listOfItem)



                case .Failure(let data):
                    print(data)






                }



        }

}


 class OrderListViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {

    @IBOutlet weak var table_OrderList: UITableView!
    var listOFOrder:NSMutableArray =[]

    override func viewDidLoad() {
        slideMenuController()?.addLeftBarButtonWithImage(UIImage(named: "ic_menu_black_24dp")!)
        slideMenuController()?.addRightBarButtonWithImage(UIImage(named: "ic_notifications_black_24dp")!)
 WebServiceManager.getDataFromService("", success: { (result) in
            listOFOrder = result as NSMutableArray
            self.recordTable?.reloadData()
            }) { (error) in

        }




    }


    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {

    }

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

        let cell : OrderList_Cell = tableView.dequeueReusableCellWithIdentifier("OrderList_Cell") as! OrderList_Cell



        return cell

    }

    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return listOFOrder.count

    }
}
于 2016-05-17T06:28:23.713 に答える