ios - pickerView 无法加载在同一 View Controller 中获取的数据(swift)

标签 ios swift uipickerview datamodel

我的 pickerview 无法从同一 View Controller 中获取的数组加载数据。但是,如果我将 fetchHistory 放入另一个 viewController(就在 historyViewController 之前)并通过导航发送数据,pickerView 会显示 confirms 数据。当我将 fetchHistory 放入 historyViewController 时,如何让它工作?或任何建议以某​​种方式放置 fetchHistory 而不是将其放入随机 viewController 的最佳方法?

历史 View Controller

var confirms = [DataWaitingConfirm]() //pickerView DataSource
override func viewDidLoad() {
    super.viewDidLoad()

    fetchHistory()//fetch data from server for 'confirms'
}

获取数据

func fetchHistory(){

    let headers = ["Authorization" : "\(TokenType!) \(Token!)"]
    Alamofire.request(.GET, "http://xxxx/history/", headers: headers, encoding: .JSON).responseJSON { response in
              switch response.result {
                  case .Success:
                     if let value = response.result.value {
                         let json = JSON(value)
                         print(json)
                         for (results,subJson):(String, JSON) in json["results"] {
                         print(subJson["status"].int)
                         if subJson["status"].intValue == 3 {
                             print("ada 3")
                             let orderReference = subJson["px_reference"].stringValue
                             let date = subJson["invoice_date_str"].stringValue
                             let totalPaid = subJson["total_paid"].stringValue

                             let orderPicker = "\(orderReference) \(date) \(totalPaid)"
                             let confirm = DataWaitingConfirm(orderReference: orderReference, pickerConfirm: orderPicker)
                             self.confirms += [confirm]
                                            }
                                        }}

            }
        case .Failure(let error):
            spinningActivity.hide(true)
            print(error)
            self.displayAlertMessage("could not fetch history")
        }
    }
}

pickerview 委托(delegate)

func pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {

    let orderToConfirm = confirms[row]
    return orderToConfirm.pickerConfirm
}

func pickerView(pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {


    return confirms.count
}

func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
    return 1
}

func pickerView(pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {

}

最佳答案

您需要调用self.pickerView.reloadAllComponents() 来触发刷新。然后将再次调用数据源方法,您更新的数据将显示在选择器 View 中。

您的 Alamofire 请求异步返回,因此您应该在 self.confirms += confirm 之后触发重新加载。

注意:您还可以考虑使用 dispatch_async(dispatch_get_main_queue(), {...})

在主线程上触发它

关于ios - pickerView 无法加载在同一 View Controller 中获取的数据(swift),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35315813/

相关文章:

ios - 如何将原始类型的 3D 数组包装在 NSArray 中?

ios - NSArray 和字节顺序

ios - 为什么没有记录约束标识符?

ios - 在swift中,当一个属性没有默认值时,其他属性持有的默认值就没有用了?

iphone - UIPickerView 列标题

ios - subview 在 iOS7 中没有接收到触摸

ios - 使用 AVAudioEngine 循环音频

swift - 我的 swift 应用程序上有很多注释。如何只在当前可见的 map 区域上显示注释?

crash - 选择器 View 上的断言失败

ios - PickerView 不显示选择分隔符 - iOS