亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS開發之表視圖詳解

2020-07-26 03:07:19
字體:
來源:轉載
供稿:網友

本文詳細介紹了表視圖的用法。具體如下:

概述

表視圖組成

表視圖是iOS開發中最重要的視圖,它以列表的形式展示數據。表視圖又一下部分組成:

  • 表頭視圖:表視圖最上邊的視圖

  • 表腳視圖:表視圖最下邊的視圖

  • 單元格(cell):表視圖中每一行的視圖

  • 節(section):由多個單元格組成,應用于分組列表

    • 節頭

    • 節腳

表視圖的相關類

UITableView繼承自UIScrollView,且有兩個協議:UITableViewDelegate和UITableViewDataSource。此外UITableViewCell類時單元格類,UITableViewController類時UITableView的控制器,UITableViewHeaderFooterView用于為節頭和節腳提供視圖。

表視圖分類

  • 普通表視圖:主要用于動態表,而動態表一般在單元格數目未知的情況下使用
  • 分組表視圖:一般用于靜態表,用來進行界面布局

單元格的組成和樣式

單元格由圖標、主標題、副標題、擴展視圖組成,可以根據需要進行選擇,其中內置的擴展視圖在枚舉類型

Swift枚舉成員 Objective-C枚舉成員 說明
none ITableViewCellAccessoryNone 沒有擴展圖標
disclosureIndicator UITableViewCellAccessoryDisclosureIndicator 擴展指示器,為箭頭+問號
detailDisclosureButton UITableViewCellAccessoryDetailDisclosureButton 細節展示圖,為問號
checkmark UITableViewCellAccessoryCheckmark 選中標志,圖標為勾
detailButton UITableViewCellAccessoryDetailButton 細節詳情展示,圖標為問號

內置的單元格樣式在枚舉類型UITableViewCellStyle中定義:

Swift枚舉成員 Objective-C枚舉成員 說明
default UITableViewCellStyleDefault 默認樣式
subtitle UITableViewCellStyleSubtitle 有圖標、主標題、副標題、副標題在主標題的下面
value1 UITableViewCellStyleValue1 有主標題、副標題,主標題左對齊、副標題右對齊,可以有圖標
2alue3 UITableViewCellStyleValue2 有主標題、副標題,主標題和副標題居中對齊,無圖標

數據源協議與委托協議

UITableViewDataSource

數據源協議主要為表視圖提供數據,主要方法如下

方法 返回類型 說明
func tableView(UITableView, cellForRowAt: IndexPath) UITableViewCell 為表視圖單元格提供數據,必須實現
tableView(UITableView, numberOfRowsInSection: Int) Int 返回某個節中的行數,必須實現
tableView(UITableView, titleForHeaderInSection: Int) String 返回節頭的標題
tableView(UITableView, titleForFooterInSection: Int) String 返回節腳的標題
numberOfSections(in: UITableView) Int 返回節的個數
sectionIndexTitles(for: UITableView) [String]? 返回表示圖節索引標題

UITableViewDelegate

委托協議主要主要用來設定表視圖中節頭和節腳的標題,以及一些動作事件,主要方法如下

方法 返回類型 說明
tableView(UITableView, didSelectRowAt: IndexPath) 單元格響應事件
tableView(UITableView, accessoryButtonTappedForRowWith: IndexPath) 擴展視圖響應事件

簡單表視圖

UIViewController根視圖控制器實現表視圖

步驟

  1. 創建一個iOS工程
  2. 從對象庫中拖入一個TableView到storyboard文件中,并將TableView覆蓋整個View
  3. 打開Table View的屬性檢查器,將PrototypeCells的值設為1,注意不要添加多個,否則會發生錯誤;此時Table View會添加一個Table View Cell。
  4. 打開Table View Cell的屬性檢查器,設置Identifier屬性。
  5. 注冊UITableViewDataSource和UITableViewDelegate協議
  6. 編寫代碼實現功能

實現

//// ViewController.swift// TableViewDemo//// Created by Michael on 2016/10/26.// Copyright © 2016年 Michael. All rights reserved.//import UIKitclass ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {  //全部數據 var listItems: NSArray! override func viewDidLoad() {  super.viewDidLoad()    //讀取資源文件數據  let listPath = Bundle.main.path(forResource: "team", ofType: "plist")  self.listItems = NSArray(contentsOfFile: listPath!) } override func didReceiveMemoryWarning() {  super.didReceiveMemoryWarning()  // Dispose of any resources that can be recreated. } //返回列表每行的視圖 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { //根據Identifier找到Cell  let cell = tableView.dequeueReusableCell(withIdentifier: "CustomId", for: indexPath)  let row = indexPath.row    let rowDict = self.listItems[row] as! NSDictionary  cell.textLabel?.text = rowDict["name"] as? String  cell.detailTextLabel?.text = "123"    let imagePath = String(format: "%@.png", rowDict["image"] as! String)  cell.imageView?.image = UIImage(named: imagePath)  cell.accessoryType = UITableViewCellAccessoryType.disclosureIndicator  return cell } //返回條目數目 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {  return self.listItems.count }  //響應條目點擊事件 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {  print("點擊事件") } }

示例圖

none模式

disclosureIndicator

UITableViewController根視圖控制器實現表視圖
步驟

  1. 創建一個iOS工程
  2. 刪除storyboard中View Controller Scene 中的View Controller,再從對象庫拖入一個Table View Controller到設計界面
  3. 打開Table View Controller屬性檢查器,勾選Is Initial View Controller選項,否則應用啟動后是黑屏
  4. 將ViewController類的父類由UIViewController改為UITableViewController
  5. 打開View Controller的屬性選擇器在Class列表中選擇ViewController
  6. UITableViewController默認以注冊UITableViewDataSource和UITableViewDelegate協議,不需要再注冊

實現

import UIKitclass ViewController: UITableViewController {  //全部數據 var listItems: NSArray! override func viewDidLoad() {  super.viewDidLoad()    //讀取資源文件數據  let listPath = Bundle.main.path(forResource: "team", ofType: "plist")  self.listItems = NSArray(contentsOfFile: listPath!) } override func didReceiveMemoryWarning() {  super.didReceiveMemoryWarning()  // Dispose of any resources that can be recreated. } //返回列表每行的視圖 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {  let cell = tableView.dequeueReusableCell(withIdentifier: "CustomId", for: indexPath)  let row = indexPath.row    let rowDict = self.listItems[row] as! NSDictionary  cell.textLabel?.text = rowDict["name"] as? String  cell.detailTextLabel?.text = "123"    let imagePath = String(format: "%@.png", rowDict["image"] as! String)  cell.imageView?.image = UIImage(named: imagePath)  cell.accessoryType = UITableViewCellAccessoryType.disclosureIndicator  return cell } //返回條目數目 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {  return self.listItems.count }  //響應條目點擊事件 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {  print("點擊事件") } }

示例圖

detailButton模式

checkmark模式

自定義單元格

步驟

  1. 創建一個表視圖工程
  2. 修改根視圖控制器為表視圖控制器UITableViewController,參照上節的步驟
  3. 從對象庫中拖入控件到單元格內部,比如Lable和ImageView
  4. 創建自定義單元格類CustomCell文件,并繼承UITableViewCell類
  5. 在設計界面中選擇View Controller Scene中的Table View Cell,并打開屬性檢查器,將Class設為CustomCell類,并設置單元格的Identifier
  6. 為單元格中的控件Label和ImageView控件連接輸出接口,將控件綁定到CustomCell類中
  7. 打開ViewController類,編寫代碼實現

實現
CustomCell類

//// CustomCell.swift// CustomCell//// Created by Michael on 2016/10/25.// Copyright © 2016年 Michael. All rights reserved.//import UIKitclass CustomCell: UITableViewCell { @IBOutlet weak var mImage: UIImageView! @IBOutlet weak var mLabel: UILabel! override func awakeFromNib() {  super.awakeFromNib()  // Initialization code } override func setSelected(_ selected: Bool, animated: Bool) {  super.setSelected(selected, animated: animated)  // Configure the view for the selected state }}

ViewController類

//// ViewController.swift// SimpleTableView//// Created by Michael on 2016/10/24.// Copyright © 2016年 Michael. All rights reserved.//import UIKitclass ViewController: UITableViewController {  var listItems: NSArray!  override func viewDidLoad() {  super.viewDidLoad()  // Do any additional setup after loading the view, typically from a nib.  let listPath = Bundle.main.path(forResource: "team", ofType: "plist")  self.listItems = NSArray(contentsOfFile: listPath!) }  override func didReceiveMemoryWarning() {  super.didReceiveMemoryWarning()  // Dispose of any resources that can be recreated. }   override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {  return self.listItems.count }    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { //找到自定義單元格  let cell:CustomCell! = tableView.dequeueReusableCell(withIdentifier: "CustomCellId", for: indexPath) as? CustomCell  //let cell = UITableViewCell(style: .value1, reuseIdentifier: "CellIdentifier")  let row = indexPath.row    let rowDict = self.listItems[row] as! NSDictionary  //設置控件屬性  cell.mLabel.text = rowDict["name"] as? String    let imagePath = String(format: "%@.png", rowDict["image"] as! String)  cell.mImage.image = UIImage(named: imagePath)  cell.accessoryType = .disclosureIndicator  return cell   }}

示例圖

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区在线播放| 欧美电影免费观看大全| 国产精品久久综合av爱欲tv| 最近2019年好看中文字幕视频| 亚洲一区二区日本| 日韩欧美亚洲一二三区| 国产一区二区三区欧美| 日韩中文字幕在线观看| 亚洲日韩中文字幕| 欧美裸体xxxxx| 日韩在线视频免费观看高清中文| 国产在线观看一区二区三区| 91色p视频在线| 亚洲欧美视频在线| 精品久久久91| 精品人伦一区二区三区蜜桃免费| 国产精品海角社区在线观看| 国产999在线| 色综合影院在线| 国产精品白丝av嫩草影院| 亚洲欧美日韩网| 亚洲国产精品久久久| 91精品国产九九九久久久亚洲| 成人黄色短视频在线观看| 色悠悠久久88| 九九精品视频在线| 精品久久久国产精品999| 久久久久久国产| 欧洲精品在线视频| 亚洲aⅴ日韩av电影在线观看| 国产综合在线视频| 国产日韩在线看片| 亚洲白虎美女被爆操| 丰满岳妇乱一区二区三区| 狠狠色狠狠色综合日日五| 中文字幕不卡在线视频极品| 国产精品视频xxxx| 色av中文字幕一区| 亚洲精品国产精品国自产在线| 色哟哟入口国产精品| 最近2019中文字幕在线高清| 久久精品这里热有精品| 国产福利视频一区二区| 成人福利在线观看| 欧美成人小视频| 久久久久久九九九| 青青a在线精品免费观看| zzijzzij亚洲日本成熟少妇| 久久视频国产精品免费视频在线| 26uuu另类亚洲欧美日本老年| 成人免费看吃奶视频网站| 欧美在线亚洲在线| 性欧美视频videos6一9| 97视频网站入口| 欧美国产视频一区二区| 在线视频免费一区二区| 91精品中国老女人| 中文字幕在线成人| 欧美精品一区二区免费| 亚洲精品日韩丝袜精品| 欧美久久精品午夜青青大伊人| 中文字幕精品久久| xxxxx成人.com| 欧美亚洲一级片| 亚洲第一网站男人都懂| 97超碰蝌蚪网人人做人人爽| 日韩福利伦理影院免费| 清纯唯美日韩制服另类| 欧美一级在线播放| 欧美亚洲成人免费| 成人黄色午夜影院| 成人疯狂猛交xxx| 欧美一乱一性一交一视频| 在线观看精品国产视频| 美女扒开尿口让男人操亚洲视频网站| 国产精品久久久久福利| 国产精品第3页| 美女国内精品自产拍在线播放| 欧美孕妇毛茸茸xxxx| 欧美另类老女人| 欧美理论电影在线播放| zzijzzij亚洲日本成熟少妇| 精品久久久久久亚洲国产300| 国产精品视频区| 欧美成人免费播放| 欧美日韩在线视频一区| 精品动漫一区二区| 国产一区二区三区毛片| 亚洲福利在线视频| 亚洲精品一区av在线播放| 激情久久av一区av二区av三区| 这里只有精品久久| 日韩av电影在线播放| 国产精品三级美女白浆呻吟| 国产精品白嫩美女在线观看| 97国产在线观看| 欧美激情精品久久久久| 中文欧美日本在线资源| 国产精品jizz在线观看麻豆| 欧美成人午夜影院| 亚洲福利视频网站| 日本精品视频在线| 91美女片黄在线观| 少妇久久久久久| 午夜剧场成人观在线视频免费观看| 在线成人激情视频| 日韩福利在线播放| 欧美做爰性生交视频| 欧美亚洲成人免费| 亚洲sss综合天堂久久| 日韩在线免费观看视频| 久久精品国产欧美激情| 精品国产欧美成人夜夜嗨| 国内外成人免费激情在线视频| 欧美日韩性视频| 91亚洲精品视频| 亚洲欧美综合精品久久成人| 色伦专区97中文字幕| 欧美性视频在线| 日韩成人在线免费观看| 91精品国产自产在线| 97国产suv精品一区二区62| 成人网中文字幕| 日韩欧美精品网址| 97在线观看视频| 成人在线一区二区| 欧美日韩国产va另类| 日本sm极度另类视频| 亚洲欧洲成视频免费观看| 一夜七次郎国产精品亚洲| 91在线视频一区| 精品亚洲夜色av98在线观看| 欧美专区中文字幕| 午夜精品一区二区三区在线播放| 亚洲激情在线视频| 欧美成人午夜剧场免费观看| 欧美精品成人91久久久久久久| 精品magnet| 黄色精品一区二区| 欧美激情在线狂野欧美精品| 午夜精品一区二区三区在线视| 欧美电影免费观看电视剧大全| 日韩成人黄色av| 日韩在线一区二区三区免费视频| 国产一区二区动漫| 91干在线观看| 91久久久久久久久久久| 97久久精品人人澡人人爽缅北| 亚洲黄色在线看| 国产z一区二区三区| 国产精品www网站| 黑人狂躁日本妞一区二区三区| 亚洲国产精彩中文乱码av在线播放| 久久夜精品香蕉| 国语自产偷拍精品视频偷| 欧美国产极速在线| 色偷偷9999www| 久久6精品影院| 国产精品自拍视频| 亚洲天堂免费观看| 中文字幕自拍vr一区二区三区| 欧美激情综合色综合啪啪五月| 欧美人交a欧美精品| 国产一区二区黄|