Frank's Book
  • Introduction
  • Privacy Policy
  • Git
    • [Git]Fully delete a git repository created with init
  • iOS
    • iOS Book
      • [iOS] Swift Coding Style
      • [iOS] UnitTest With XCode
      • [iOS] Build a Universal Framework for iOS using Swift
      • [iOS] Memory Management
      • [iOS] GCD And Operation Queue
      • [iOS] MVVM
      • [iOS] CoreData
      • [iOS] KVO & KVC
      • [iOS] Asynchronous Operation
      • [iOS] URLSession
      • [iOS] NSTimer & CADisplayLink
      • [iOS] UITextField & UITestView
      • [iOS] UITableView & UICollectionView
      • [iOS] Codable
      • [iOS] Array的sort, filter, map, reduce 函式
      • [iOS] Class vs Struct
      • [iOS] Reference Type vs Value Type
      • [iOS] Object
      • [iOS] IBDesignable & IBInspectable
  • Jenkins
    • Jenkins & Docker
      • [Docker] Docker Commands
      • [Docker] 1. Setup Jenkins with Docker on Mac
      • [Docker] 2. Jenkins建立Mac子節點
      • [Docker] 3. Mac節點build Xcode project設定
      • [Jenkins] 1. Install Jenkins
      • [Jenkins] 2. Change Default User Of Jenkins
      • [Jenkins] 3. Integration with Git
      • [Jenkins] 4. Integration with XCode
      • [Jenkins] 5. Integration with Unit Test
      • [Jenkins] 6. Uninstall Jenkins
      • [Jenkins] 7. Jenkins Commands
      • [Jenkins] 8. Jenkins Plugins
      • [Jenkins] 9. Problem Solving
  • Flutter
    • Flutter Book
      • [Flutter] Update your Flutter path (Mac OS)
      • [Flutter] Release Command
      • [Flutter] Life Cycles
      • [Flutter] AppLifecycleState
      • [Flutter] Navigator Pop時回傳資料
      • [Flutter] Install appium-flutter-driver
  • Leet Code
    • LeetCode Solutions
      • [LeetCode] 1. Two Sum [Easy]
      • [LeetCode] 2. Add Two Numbers [Medium]
      • [LeetCode] 3. Longest Substring Without Repeating Characters [Medium]
      • [LeetCode] 5. Longest Palindromic Substring [Medium]
      • [LeetCode] 7. Reverse Integer [Easy] [LeetCode]
      • [LeetCode] 8. String to Integer (atoi)
      • [LeetCode] 11. Container With Most Water
      • [LeetCode] 13. Roman to Integer
      • [LeetCode]14. Longest Common Prefix
      • [LeetCode] 15. 3Sum
      • [LeetCode] 17. Letter Combinations of a Phone Number
      • [LeetCode] 19. Remove Nth Node From End of List
      • [LeetCode] 20. Valid Parentheses
      • [LeetCode] 21. Merge Two Sorted Lists
      • [LeetCode] 22. Generate Parentheses
      • [LeetCode] 26. Remove Duplicates from Sorted Array
      • [LeetCode] 28. Implement strStr()
      • [LeetCode] 33. Search in Rotated Sorted Array
      • [LeetCode] 34. Find First and Last Position of Element in Sorted Array
      • [LeetCode]36. Valid Sudoku
      • [LeetCode] 38. Count and Say
      • [LeetCode] 46. Permutations
      • [LeetCode] 48. Rotate Image
      • [LeetCode] 49. Group Anagrams
  • Git
    • Git Commands
      • [LeetCode] 50. Pow(x, n)
  • About Author
    • Frank Chen
Powered by GitBook
On this page
  • UITableView
  • UICollectionView
  1. iOS
  2. iOS Book

[iOS] UITableView & UICollectionView

UITableView

Initialization:

@IBOutlet weak var tableView: UITableView!

override func viewDidLoad() {
   super.viewDidLoad()
   self.initTableView()
}

private func initTableView() {
   self.tableView.delegate = self
   self.tableView.dataSource = self
   self.tableView.tableFooterView = UIView(frame: .zero) //設定Tableview 的cells下方為空白而不會有格線
   self.tableView.register(UINib(nibName: "MyTableViewCell", bundle: nil), forCellReuseIdentifier: "MyTableViewCell")
   self.tableView.addSubview(self.refreshControl)
}

RefreshControl:

lazy var refreshControl: UIRefreshControl = {
   let refreshControl = UIRefreshControl()
    refreshControl.addTarget(self, action: #selector(ViewController.handleRefresh(_:)), for: UIControlEvents.valueChanged)
    refreshControl.tintColor = UIColor.blue   
    return refreshControl
}()

func handleRefresh(_ refreshControl: UIRefreshControl) {
    //TODO
    self.tableView.reloadData()
    refreshControl.endRefreshing()
}

self.tableView.addSubview(self.refreshControl)

常用的UITableViewDelegate:

func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
}

必要的UITableViewDataSource:

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return 10
}
    
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "MyTableViewCell", for: indexPath) as! MyTableViewCell
    return cell
}

Insert rows:

dataArray.insert(contentsOf: ["aaa", "bbb"], at: 1) 

tableView.beginUpdates() 
let indexPaths = [IndexPath(row: 1, section: 0), IndexPath(2, section: 0)]
tableView.insertRows(at: indexPaths, with: UITableViewRowAnimation.automatic)
tableView.endUpdates()

UICollectionView

Initialization:

 @IBOutlet weak var collectionView: UICollectionView!
  
 override func viewDidLoad() {
     super.viewDidLoad()
     self.initClooectionView()
 }

private func initClooectionView() {
   self.collectionView.dataSource = self
   self.collectionView.delegate = self
   self.collectionView.register(UINib(nibName: "MyCollectionViewCell", bundle: nil), forCellWithReuseIdentifier: "MyCollectionViewCell")
}

layout: UICollectionViewFlowLayout

override func viewWillAppear(_ animated: Bool) {
   super.viewWillAppear(animated)
   self.initClooectionViewLayout()
}

func initClooectionViewLayout() {
   self.view.layoutIfNeeded() // this line let you can access it's frame and it will have the same value as you print in viewDidAppear
   let edgeIinset:CGFloat = 20 //邊界的間距
   let gap:CGFloat = 10 //Cell與Cell之間的間距
   self.collectionView.contentInset = UIEdgeInsets(top: edgeIinset, left: edgeIinset, bottom: edgeIinset, right: edgeIinset)
   let cellWidth = (self.view.frame.size.width - (2 * edgeIinset) - (2 * gap))/3.0
   //cellWidth為一橫排3個Cell的寬度

   let flowLayout = UICollectionViewFlowLayout()
   flowLayout.scrollDirection = .vertical //垂直scroll
   flowLayout.minimumLineSpacing = gap //The minimum spacing to use between lines of items in the grid.
   flowLayout.minimumInteritemSpacing = gap //The minimum spacing to use between items in the same row.
   flowLayout.itemSize = CGSize(width: cellWidth, height: cellWidth)
   self.collectionView.collectionViewLayout = flowLayout
   self.collectionView.setContentOffset(CGPoint(x: 0, y: 0), animated: true)
 }

常用的UICollectionViewDelegate:

func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
     //TODO 
}

必要的UICollectionViewDataSource:

func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return 10
}
    
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "MyCollectionViewCell", for: indexPath as IndexPath) as! MyCollectionViewCell
    return cell
}
Previous[iOS] UITextField & UITestViewNext[iOS] Codable

Last updated 6 years ago