我正在尝试获取一个 TableView 来加载从 imgur 获取的一些 JSON 数据。我可以向后端发出请求,后端获取 imgur 数据,将其返回给我,然后我可以填充表。然而,我遇到了一个非常奇怪的问题,数据最后被切断。 Here是一张图片。如果我尝试进行另一次搜索,它不会将更多数据加载到表中,所以很明显,当我这样做时,我会破坏它。我真的不知道我做错了什么。我还试图让它在某个时候可以通过模态点击,并且使可重用单元出队可能也不正确,但我想在这个问题之后我会到达那里。
无论如何,任何帮助将不胜感激。
class ViewController3: UIViewController, UITextFieldDelegate,UITableViewDataSource {
var dataState: Data?
var linkArray = [String]()
var titleArray = [String]()
@IBOutlet weak var tableView: UITableView!
@IBOutlet weak var SearchTextField: UITextField!
@IBAction func SearchButton(_ sender: Any) {
let urlString = "http://localhost:3000/getimages"
Alamofire.request(urlString, method: .post, parameters: ["search": SearchTextField.text!],encoding: JSONEncoding.default, headers: nil).responseJSON {
response in
switch response.result {
case .success:
let json = JSON(response.data!)
for (_, subJson) in json["data"] {
if let link = subJson["link"].string {
self.linkArray.append(link)
}
if let title = subJson["title"].string{
self.titleArray.append(title)
}
}
print("this is linkArray ", self.linkArray)
print("this is titleArray ", self.titleArray)
self.dataUpdated()
break
case .failure(let error):
print(error)
}
}
}
@IBAction func BackToTabControl(_ sender: Any) {
let storyBoard: UIStoryboard = UIStoryboard(name: "Main", bundle: nil)
let tabBarVC = storyBoard.instantiateViewController(withIdentifier: "tabBarController") as! UITabBarController
if let vc1 = tabBarVC.viewControllers?.first as? ViewController1 {
vc1.dataState = dataState
}
let appDelegate = UIApplication.shared.delegate as! AppDelegate
appDelegate.window?.rootViewController = tabBarVC
}
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
override func viewDidLoad() {
super.viewDidLoad()
self.tableView.bounces = true
SearchTextField.returnKeyType = UIReturnKeyType.done
SearchTextField.delegate = self
tableView.dataSource = self
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return titleArray.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cellReuseIdentifier")! //1.
let text = titleArray[indexPath.row] //2.
cell.textLabel?.text = text //3.
return cell //4.
}
func dataUpdated() {
DispatchQueue.main.async {
self.tableView.reloadData()
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
}
最佳答案
下一步尝试:
if let label = cell.textLabel {
label.text = text
label.sizeToFit()
}
关于ios - 添加 JSON 数据时 UITableView 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44766340/