我有一个第一个viewcontroller,它包含一个分段控制器(SJSegmented Controller)。它附带了一个函数,我可以知道用户在哪个段并更改加载其他视图控制器数据的php但是当我到达包含表视图的视图控制器时,Viewdidload和Viewdidappear只执行一次并且在用户更改分段后,未加载Viewdidload和Viewdidappear。
以下是来自第一个视图控制器的分段控制器的代码。
func didMoveToPage(_ controller: UIViewController, segment: SJSegmentTab?, index: Int) {
if selectedSegment != nil {
selectedSegment?.titleColor(.gray)
}
if segments.count > 0 {
selectedSegment = segments[index]
}
// Checks witch segment the user is at and change the php to load accordingly
let CurrSeg = index
print(CurrSeg)
let Curr = String(CurrSeg)
if Curr == "0" {
UserDefaults.standard.set(“xyz.php”, forKey: "DealsPHP")
UserDefaults.standard.synchronize()
} else if Curr == "1" {
// UserDefaults.standard.set("hwy.php", forKey: "DealsPHP")
// UserDefaults.standard.synchronize()
} else if Curr == "2" {
UserDefaults.standard.set("uys.php", forKey: "DealsPHP")
UserDefaults.standard.synchronize()
} else if Curr == "3" {
UserDefaults.standard.set("wrt.php", forKey: "DealsPHP")
UserDefaults.standard.synchronize()
}
}
我想在执行didMoveToPage时重新加载另一个视图控制器的表视图。
第二个视图控制器的代码(包括表格视图)
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
tableView.reloadData()
}
PS:执行didMoveToPage时更改php并使用更改后的php加载相同的视图控制器。
以下是填充表格视图的代码:
func get() {
let DealsPHP: String = (UserDefaults.standard.object(forKey: "DealsPHP") as? String)!
let url = URL(string: DealsPHP)
let data = try? Data(contentsOf: url!)
if data == nil {
// Create the alert controller
let alertController = UIAlertController(title: "No Internet Connection", message: "It looks like you aren't connected to the Internet. Please check your internet connection and try again.", preferredStyle: .alert)
// Create the actions
let okAction = UIAlertAction(title: "Try Again", style: UIAlertActionStyle.default) {
UIAlertAction in
self.get()
}
// Add the actions
alertController.addAction(okAction)
// Present the controller
self.present(alertController, animated: true, completion: nil)
} else {
self.values = try! JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableContainers) as! NSArray
self.tableView.reloadData()
}
}
答案 0 :(得分:0)
这个问题是由@sweepez解决的。 我在中添加了此代码,如果Curr ==" 1" {} ** 在 ** func didMoveToPage 这个重新加载了tableview evreytime段数据的变化
let myController = controller as! YourControllerName
myController.get()