Table 视图未显示单元格 Swift
Table View not showing the Cells Swift
我创建了一家餐厅 class 并建立了所有连接以显示单元格,但是当我点击 运行 时,它没有显示我创建的所有商店。
这是我的代码:
import UIKit
class RestaurantTableViewController: UITableViewController {
var restaurants:[Resturant] = [
Resturant(name: "Hardees", type: "Burger", location: "Many", image: "Hardees.jpg", isVisited: false), Resturant(name: "Shake Shack", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Burgery", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Dairy Queen", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Elevation Burger", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Fat Burger", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false)
]
override func viewDidLoad() {
super.viewDidLoad()
// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false
// Uncomment the following line to display an Edit button in the navigation bar for this view controller.
// self.navigationItem.rightBarButtonItem = self.editButtonItem()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return restaurants.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cellIdentifier = "Cell"
let cell = tableView.dequeueReusableCell(withIdentifier: cellIdentifier, for: indexPath) as! CustomTableViewCell
// Configure the cell...
cell.nameLabel.text = restaurants[indexPath.row].name
cell.thumbnailImageView.image = UIImage(named: restaurants[indexPath.row].image)
cell.locationLabel.text = restaurants[indexPath.row].location
cell.typeLabel.text = restaurants[indexPath.row].type
cell.accessoryType = restaurants[indexPath.row].isVisited ? .checkmark : .none
return cell
}
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
// Delete the row from the data source
restaurants.remove(at: indexPath.row)
}
tableView.deleteRows(at: [indexPath], with: .fade)
}
override func tableView(_ tableView: UITableView, editActionsForRowAt indexPath: IndexPath) -> [UITableViewRowAction]? {
// Social Sharing Button
let shareAction = UITableViewRowAction(style: UITableViewRowActionStyle.default, title: "Share", handler: { (action, indexPath) -> Void in
let defaultText = "Just checking in at " + self.restaurants[indexPath.row].name
if let imageToShare = UIImage(named: self.restaurants[indexPath.row].image) {
let activityController = UIActivityViewController(activityItems: [defaultText, imageToShare], applicationActivities: nil)
self.present(activityController, animated: true, completion: nil)
}
})
// Delete button
let deleteAction = UITableViewRowAction(style: UITableViewRowActionStyle.default, title: "Delete",handler: { (action, indexPath) -> Void in
// Delete the row from the data source
self.restaurants.remove(at: indexPath.row)
self.tableView.deleteRows(at: [indexPath], with: .fade)
})
shareAction.backgroundColor = UIColor(red: 48.0/255.0, green: 173.0/255.0, blue: 99.0/255.0, alpha: 1.0)
deleteAction.backgroundColor = UIColor(red: 202.0/255.0, green: 202.0/255.0, blue: 203.0/255.0, alpha: 1.0)
return [deleteAction, shareAction]
}
// MARK: -
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if segue.identifier == "showRestaurantDetail" {
if let indexPath = tableView.indexPathForSelectedRow {
let destinationController = segue.destination as! ResturantDetailViewController
destinationController.resturant = restaurants[indexPath.row]
}
}
}
}
这是我的 githu 仓库
嘿,我解决了你的问题,在界面生成器中,当你需要将它设置为 RestaurantTableViewController
的实际文件名时,你已将自定义 class 设置为 RestaurantTableTableView
。
在 Storyboard 中,您正在 linking "Burger restaurant" table 控制器以:
ResturantTableTableViewController
就像您的文件 "ResturantTableTableViewController.swift",但在此文件中,您已将其声明为:
class RestaurantTableViewController: UITableViewController {
故事板忽略文件名,但使用您在文件中声明的名称。
将文件名和 link 故事板更改为相同的 class。或者您可以将 "ResturantTableTableViewController.swift" 文件中的 class-name 更改为与文件名 ("ResturantTableTableViewController").
相同的名称
我创建了一家餐厅 class 并建立了所有连接以显示单元格,但是当我点击 运行 时,它没有显示我创建的所有商店。
这是我的代码:
import UIKit
class RestaurantTableViewController: UITableViewController {
var restaurants:[Resturant] = [
Resturant(name: "Hardees", type: "Burger", location: "Many", image: "Hardees.jpg", isVisited: false), Resturant(name: "Shake Shack", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Burgery", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Dairy Queen", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Elevation Burger", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false), Resturant(name: "Fat Burger", type: "Burger", location: "Gulf Mall", image: "shakeshack.jpg", isVisited: false)
]
override func viewDidLoad() {
super.viewDidLoad()
// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false
// Uncomment the following line to display an Edit button in the navigation bar for this view controller.
// self.navigationItem.rightBarButtonItem = self.editButtonItem()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return restaurants.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cellIdentifier = "Cell"
let cell = tableView.dequeueReusableCell(withIdentifier: cellIdentifier, for: indexPath) as! CustomTableViewCell
// Configure the cell...
cell.nameLabel.text = restaurants[indexPath.row].name
cell.thumbnailImageView.image = UIImage(named: restaurants[indexPath.row].image)
cell.locationLabel.text = restaurants[indexPath.row].location
cell.typeLabel.text = restaurants[indexPath.row].type
cell.accessoryType = restaurants[indexPath.row].isVisited ? .checkmark : .none
return cell
}
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
// Delete the row from the data source
restaurants.remove(at: indexPath.row)
}
tableView.deleteRows(at: [indexPath], with: .fade)
}
override func tableView(_ tableView: UITableView, editActionsForRowAt indexPath: IndexPath) -> [UITableViewRowAction]? {
// Social Sharing Button
let shareAction = UITableViewRowAction(style: UITableViewRowActionStyle.default, title: "Share", handler: { (action, indexPath) -> Void in
let defaultText = "Just checking in at " + self.restaurants[indexPath.row].name
if let imageToShare = UIImage(named: self.restaurants[indexPath.row].image) {
let activityController = UIActivityViewController(activityItems: [defaultText, imageToShare], applicationActivities: nil)
self.present(activityController, animated: true, completion: nil)
}
})
// Delete button
let deleteAction = UITableViewRowAction(style: UITableViewRowActionStyle.default, title: "Delete",handler: { (action, indexPath) -> Void in
// Delete the row from the data source
self.restaurants.remove(at: indexPath.row)
self.tableView.deleteRows(at: [indexPath], with: .fade)
})
shareAction.backgroundColor = UIColor(red: 48.0/255.0, green: 173.0/255.0, blue: 99.0/255.0, alpha: 1.0)
deleteAction.backgroundColor = UIColor(red: 202.0/255.0, green: 202.0/255.0, blue: 203.0/255.0, alpha: 1.0)
return [deleteAction, shareAction]
}
// MARK: -
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if segue.identifier == "showRestaurantDetail" {
if let indexPath = tableView.indexPathForSelectedRow {
let destinationController = segue.destination as! ResturantDetailViewController
destinationController.resturant = restaurants[indexPath.row]
}
}
}
}
这是我的 githu 仓库
嘿,我解决了你的问题,在界面生成器中,当你需要将它设置为 RestaurantTableViewController
的实际文件名时,你已将自定义 class 设置为 RestaurantTableTableView
。
在 Storyboard 中,您正在 linking "Burger restaurant" table 控制器以:
ResturantTableTableViewController
就像您的文件 "ResturantTableTableViewController.swift",但在此文件中,您已将其声明为:
class RestaurantTableViewController: UITableViewController {
故事板忽略文件名,但使用您在文件中声明的名称。
将文件名和 link 故事板更改为相同的 class。或者您可以将 "ResturantTableTableViewController.swift" 文件中的 class-name 更改为与文件名 ("ResturantTableTableViewController").
相同的名称