Reputation: 14470
Hi I have a TableViewController
with two static cells, however when displayed, it shows the two static cells, and then all the other empty cells for the tableview. However I don't want to display those cells as they are useless. How do I hide the rest of the cells apart from the two static cell?
Upvotes: 134
Views: 70471
Reputation: 2684
tableView.tableFooterView = UIView.init(frame: CGRect.zero)
Call this code in viewDidLoad
method.
Upvotes: 4
Reputation: 855
if you want to remove rows for all UITableViews
in your app, just add an extension like this:
Swift 5.0
extension UITableView {
override open func didMoveToSuperview() {
super.didMoveToSuperview()
self.tableFooterView = UIView()
}
Upvotes: 3
Reputation: 920
Add Below Code in your "override func viewDidLoad()" Or "override func viewWillAppear(_ animated: Bool)" functions.
tblOutletName.tableFooterView = UIView()
Upvotes: 1
Reputation: 3655
Setting the tableFooterView
should remove extra cell like views.
@IBOutlet weak var tableView: UITableView! {
didSet {
tableView.tableFooterView = UIView(frame: .zero)
}
}
Upvotes: 7
Reputation: 135
Abobe anwer is right. We can achieve this by adding
tableView.tableFooterView = UIView() // to remove extra cells in tableView
Upvotes: -2
Reputation: 3767
Select your UITableView, go to the attribute inspector and change the style to Grouped.
Upvotes: 23
Reputation: 1373
Based on above answers in swift.
tableView.tableFooterView = UIView(frame: .zero)
Upvotes: 3
Reputation: 1976
Swift 4 Elaborating on HorseT's answer, first control drag from your Table View in your storyboard, to your View Controller class and create an outlet called tableView.
@IBOutlet weak var tableView: UITableView!
Then, your viewDidLoad in your View Controller should look something like this:
override func viewDidLoad() {
super.viewDidLoad()
tableView.dataSource = self
tableView.delegate = self
tableView.tableFooterView = UIView()
}
Upvotes: 3
Reputation: 127
I tried the tableview.tableFooterView = UIView() and it did not work for me. I am using a custom TableViewViewCell, perhaps that is why.
I did find a hack tho. In my func numberOfRowsInSection
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return yourArrayClass.count - 1
}
And that makes my extra blank custom UITableViewCell not display anymore. Of course its the extra blank one. I will test it some more by adding more Cells. For reference, I am using Swift 3, Firebase, a custom cell class, inside the cellForRowAt function.
Upvotes: -3
Reputation: 1048
Simply add:
tableView.tableFooterView = UIView()
Explanation:
This is totally valid and works perfectly in swift 3.By Since you are setting an empty UIView() object to the property, Setting tableFooterView to UIView() removes the rows.
Upvotes: 1
Reputation: 1260
You can achieve this also in Storyboard by simply dragging a view into the table view's footer area, and then set its height and background color to 1 and clear respectively using the property inspector.
(This assumes that you either can't or don't want to just use the Group style setting for some reason. Otherwise, just do that.)
Upvotes: 3
Reputation: 1980
To add to this, the reason why setting tableFooterView
to UIView()
removes the rows is because you are setting an empty UIView()
object to the property. As per the Apple documentation:
var tableFooterView: UIView?
Therefore setting an empty UIView() will display nothing below your data for this property.
You can bring the empty rows back by resetting tableFooterView
to the default value, like so:
tableView.tableFooterView = nil
Upvotes: 7
Reputation: 6592
in your viewDidLoad()
function add this line of code:
tableView.tableFooterView = UIView()
Upvotes: 450