从Swift 4的闭包中获取完成块之外的变量值

时间:2018-10-09 16:30:33

标签: ios swift post closures

我有一个用swift 4编写的项目。当我尝试访问闭包内部的值时,它会产生nil。这是我的代码:

import UIKit
import SwiftyJSON

class TchatViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
    let appDelegate = UIApplication.shared.delegate as! AppDelegate
    var coach_ID: String!

    var responseArr = [JSON]()
    var responseInfo = [JSON]()

    var userIDS: String?
    var typeUsers: String?
    var chatID: String?
    var appdict: NSDictionary?

    @IBOutlet weak var tblMessage: UITableView!
    @IBOutlet weak var txtMsgs: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()

        let userInfo = DataManager.sharedInstance.loadUser()
        getAvisList(user: userInfo!)

        tblMessage.delegate = self
        tblMessage.dataSource = self

        print("CoachIDS",coach_ID!)
    }

    func getAvisList(user: User) {
        let appDelegate = UIApplication.shared.delegate as! AppDelegate
        let userId = user.id
        print("chatuserId",userId!)
        self.userIDS = userId
        let userType = Int(user.type!)
        print("chatusertype",userType!)

        // var url: String = ""

        self.typeUsers = user.type!

        let todosEndpoint: String = "http://testchat.com/api/chats/createChatroomMobile"

        let newTodo = ["user_type":userType!, "user_id":userId!,"coach_id":coach_ID!] as [String : Any]

        let loader = appDelegate.showLoading()
        WebServices.sharedInstance.post(toURL: todosEndpoint, withParams: newTodo, successHandler: { (jsonData) in
            print("chatroom data: \(jsonData)")
            // self.responseArr  = jsonData.arrayValue
            let responseInfo = jsonData.dictionaryValue
            let appdict = (responseInfo as Any as! NSDictionary).value(forKey: "chatroomID")!

            print("Chatroom==",appdict) // the value gets printed here.

            let strinDuration:NSString = NSString(format:"http://testchat.com/api/chats/room/id/%@",appdict as! CVarArg)  as String as String as NSString

            print("strinDuration ==",strinDuration)

            WebServices.sharedInstance.get(toURL: strinDuration as String, successHandler: { (jsonData) in
                print("ChatHistroy: \(jsonData)")

                self.responseArr  = jsonData.arrayValue
                self.responseArr = self.responseArr.reversed()
                self.tblMessage.reloadData()
                // I am getting this data for the table view.
            }) { (error) in
                print(error)
            }

            self.appDelegate.dismissLoading(loader)
        }) { (error) in
            print(error)
            self.appDelegate.dismissLoading(loader)
        }
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // return self.avisList.count
        return self.responseArr.count
    }

    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 200.0
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell: TChatCell = tableView.dequeueReusableCell(withIdentifier: "tchatcell") as! TChatCell

        let index = self.responseArr.count - indexPath.row - 1
        cell.descriptionMsg.text = self.responseArr[index]["message"].stringValue

        return cell
    }

    //Till here, it works fine. But below from here, the value gets nil.

    @IBAction func sendMessage(_ sender: Any) {
        let todosEndpoint: String = "http://testchat5479.ilovemydietcoach.com/api/chats/addMessage"

        print("self.userIDS",self.userIDS!) //It gives the value.
        print("self.typeUsers",self.typeUsers!) //It gives the value.
        print("self.chatID===", appdict)// The value of appdict is nil here.
    }
}

/// 我也为发布和获取方法编写了Web服务代码。

class WebServices: NSObject {

static let sharedInstance = WebServices()

func post(toURL urlString:String, withParams postParams:Parameters, successHandler: @escaping (( _ jsonData:JSON) -> Void), failureHandler: @escaping((_ error:Error) -> Void)) {
    let url = URL(string: urlString)!

    let headers = ["Accept":"application/json", "Content-Type":"application/json"]

    Alamofire.request(url, method: .post, parameters: postParams, encoding: JSONEncoding.default, headers: headers).responseJSON { (response) -> Void in

        switch response.result {
        case .success(let value):
            let tempInfo = JSON(value)
            successHandler(tempInfo)
        case .failure(let error):
            failureHandler(error)
        }
    }

}
   func get(toURL urlString:String, successHandler: @escaping (( _ jsonData:JSON) -> Void), failureHandler: @escaping((_ error:Error) -> Void)) {
    let url = URL(string: urlString)!

    let headers = ["Accept":"application/json", "Content-Type":"application/json"]

    Alamofire.request(url, method: .get, encoding: JSONEncoding.default, headers: headers).responseJSON { (response) in
        switch response.result {
        case .success(let value):
            let tempInfo = JSON(value)
            successHandler(tempInfo)
        case .failure(let error):
            failureHandler(error)
        }
    }

}

}

该appdict在闭包内部具有一定的价值,但在这里没有价值。我必须在这里使用appdict的价值。如何在Swift 4中解决?

1 个答案:

答案 0 :(得分:0)

在闭包中分配给appdict时,您使用let来隐藏成员变量:

let appdict = (responseInfo as Any as! NSDictionary).value(forKey: "chatroomID")!

使用 let ,您将创建一个遮盖成员 appdict 的局部变量。如果删除 let ,则将分配给成员变量。