一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Swift - Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

2021-01-08 14:48乞力馬扎羅的雪雪 Swift

這篇文章主要為大家詳細(xì)介紹了Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

在Android中我們常常使用ListView來(lái)表示列表,來(lái)顯示類(lèi)似的呈現(xiàn)列表樣式的結(jié)果。來(lái)到iOS中,這種控件稱(chēng)之為TableView。這里我們將會(huì)通過(guò)使用ScrollView和TableView結(jié)合的方式來(lái)實(shí)現(xiàn)可以側(cè)滑顯示的列表,這將會(huì)大大提高用戶(hù)體驗(yàn)。先看一下實(shí)現(xiàn)效果:

Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

 

Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

具體實(shí)現(xiàn)步驟如下:

(1)創(chuàng)建一個(gè)iOS項(xiàng)目,Language選擇Swift,然后在Main.storyboard中拖入一個(gè)ScrollView,即滾動(dòng)控件,界面設(shè)計(jì)如圖:

Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

(2)然后拖動(dòng)控件綁定到代碼中:

?
1
@IBOutlet weak var dynamicScrollView: UIScrollView!

(3)我將會(huì)在一個(gè)ScrollView中實(shí)現(xiàn)三個(gè)TableView,三個(gè)列表可以通過(guò)手指的左右滑動(dòng)進(jìn)行切換,一些變量定義如下:

?
1
2
3
4
5
6
7
var tableView11:UITableView = UITableView()
var tableView22:UITableView = UITableView()
var tableView33:UITableView = UITableView()
 
var cell1 = UITableViewCell()
var cell2 = UITableViewCell()
var cell3 = UITableViewCell()

(4)然后在viewDidLoad()中設(shè)置委托和數(shù)據(jù)源,同時(shí)該類(lèi)要實(shí)現(xiàn)以下接口:UIScrollViewDelegate,UITableViewDelegate,UITableViewDataSource

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
override func viewDidLoad() {
  super.viewDidLoad()
 
  tableView11.delegate = self
  tableView11.dataSource = self
   
  tableView22.delegate = self
  tableView22.dataSource = self
   
  tableView33.delegate = self
  tableView33.dataSource = self
   
  dynamicScroll()
  initCustomTableView()
}

(5)實(shí)現(xiàn)dynamicScroll()方法,該方法是對(duì)ScrollView控件的滾動(dòng)進(jìn)行控制,同時(shí)把三個(gè)TableView加入到ScrollView中:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
func dynamicScroll(){ //動(dòng)態(tài)信息的滾動(dòng);
  let tableW:CGFloat = self.dynamicScrollView.frame.size.width;
  let tableH:CGFloat = self.dynamicScrollView.frame.size.height;
  var tableY:CGFloat = 0;
  var totalCount:NSInteger = 3;//只有三列;
 
    var tableView1:UITableView = UITableView();
    var tableView2:UITableView = UITableView();
    var tableView3:UITableView = UITableView();
   
    tableView11.frame = CGRectMake(CGFloat(0) * tableW, tableY, tableW, tableH);
    tableView22.frame = CGRectMake(CGFloat(1) * tableW, tableY, tableW, tableH);
    tableView33.frame = CGRectMake(CGFloat(2) * tableW, tableY, tableW, tableH);
     
    dynamicScrollView.addSubview(tableView11);
    dynamicScrollView.addSubview(tableView22);
    dynamicScrollView.addSubview(tableView33);
   
  let contentW:CGFloat = tableW * CGFloat(totalCount);//這個(gè)表示整個(gè)ScrollView的長(zhǎng)度;
  dynamicScrollView.contentSize = CGSizeMake(contentW, 0);
  dynamicScrollView.pagingEnabled = true;
  dynamicScrollView.delegate = self;
   
}

(6)實(shí)現(xiàn)initCustomTableView()方法,該方法是對(duì)TableView的中的Cell設(shè)置ID號(hào),用來(lái)標(biāo)識(shí)不同的TableView :

?
1
2
3
4
5
6
func initCustomTableView(){  //初始化動(dòng)態(tài)信息中的TableView
   
  tableView11.registerClass(UITableViewCell.self, forCellReuseIdentifier:"cell1")
  tableView22.registerClass(UITableViewCell.self, forCellReuseIdentifier:"cell2")
  tableView33.registerClass(UITableViewCell.self, forCellReuseIdentifier:"cell3")
}

(7)最后實(shí)現(xiàn)UITableViewDataSource中的兩個(gè)必須實(shí)現(xiàn)的方法,是對(duì)三個(gè)TableView的數(shù)據(jù)源將進(jìn)行設(shè)置:需要顯示的內(nèi)容可以在這里進(jìn)行添加:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{
 
 return 5 //返回TableView的Cell數(shù)量,可以動(dòng)態(tài)設(shè)置;
}
 
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{
  
 var cell = UITableViewCell()
  
 switch tableView {
  
 case tableView11:
  cell1 = tableView11.dequeueReusableCellWithIdentifier("cell1") as! UITableViewCell
  cell1.textLabel!.text = String(format:"昨天")
  cell = cell1
  break
 
 case tableView22:
  cell2 = tableView22.dequeueReusableCellWithIdentifier("cell2") as! UITableViewCell
  cell2.textLabel!.text = String(format:"今天")
  cell = cell2
 
  break
   
 case tableView33:
  cell3 = tableView33.dequeueReusableCellWithIdentifier("cell3") as! UITableViewCell
  cell3.textLabel!.text = String(format:"明天")
  cell = cell3
 
  break
   
 default:
  break
 }
  
 return cell
}

(8)最后運(yùn)行程序,就可以實(shí)現(xiàn)本文開(kāi)頭的多個(gè)TableView在ScrollView中通過(guò)側(cè)滑就可以切換的效果,雖然屏幕大小有限,我們可以通過(guò)視圖的切換顯示豐富的內(nèi)容。

在iOS的開(kāi)發(fā)中,TableView和ScrollView是兩個(gè)最為常用,使用最為靈活的控件,必須要好好掌握。

github主頁(yè):https://github.com/chenyufeng1991  。歡迎大家訪(fǎng)問(wèn)!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/CHENYUFENG1991/article/details/47400005

延伸 · 閱讀

精彩推薦
  • SwiftSwift教程之基礎(chǔ)數(shù)據(jù)類(lèi)型詳解

    Swift教程之基礎(chǔ)數(shù)據(jù)類(lèi)型詳解

    這篇文章主要介紹了Swift教程之基礎(chǔ)數(shù)據(jù)類(lèi)型詳解,本文詳細(xì)講解了Swift中的基本數(shù)據(jù)類(lèi)型和基本語(yǔ)法,例如常量和變量、注釋、分號(hào)、整數(shù)、數(shù)值類(lèi)型轉(zhuǎn)換等...

    Swift教程網(wǎng)5162020-12-18
  • SwiftSwift的74個(gè)常用內(nèi)置函數(shù)介紹

    Swift的74個(gè)常用內(nèi)置函數(shù)介紹

    這篇文章主要介紹了Swift的74個(gè)常用內(nèi)置函數(shù)介紹,這篇文章列舉出了所有的Swift庫(kù)函數(shù),內(nèi)置函數(shù)是指無(wú)需引入任何模塊即可以直接使用的函數(shù),需要的朋友可...

    Swift教程網(wǎng)5802020-12-19
  • SwiftSwift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

    Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果

    這篇文章主要為大家詳細(xì)介紹了Swift實(shí)現(xiàn)多個(gè)TableView側(cè)滑與切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    乞力馬扎羅的雪雪5822021-01-08
  • Swiftswift where與匹配模式的實(shí)例詳解

    swift where與匹配模式的實(shí)例詳解

    這篇文章主要介紹了swift where與匹配模式的實(shí)例詳解的相關(guān)資料,這里附有簡(jiǎn)單的示例代碼,講的比較清楚,需要的朋友可以參考下...

    追到夢(mèng)的魔術(shù)師14382021-01-06
  • Swiftmac git xcrun error active developer path 錯(cuò)誤

    mac git xcrun error active developer path 錯(cuò)誤

    本文主要是講訴了如何解決在mac下使用git;xcode4.6的環(huán)境時(shí),出現(xiàn)了錯(cuò)誤(mac git xcrun error active developer path)的解決辦法,希望對(duì)大家有所幫助...

    Swift教程網(wǎng)2232020-12-16
  • SwiftSwift使用CollectionView實(shí)現(xiàn)廣告欄滑動(dòng)效果

    Swift使用CollectionView實(shí)現(xiàn)廣告欄滑動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了Swift使用CollectionView實(shí)現(xiàn)廣告欄滑動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    Stevin的技術(shù)博客12372021-01-13
  • SwiftSwift中轉(zhuǎn)義閉包示例詳解

    Swift中轉(zhuǎn)義閉包示例詳解

    在Swift 中的閉包類(lèi)似于結(jié)構(gòu)塊,并可以在任何地方調(diào)用,下面這篇文章主要給大家介紹了關(guān)于Swift中轉(zhuǎn)義閉包的相關(guān)資料,需要的朋友可以參考下...

    小小小_小朋友11412021-12-26
  • SwiftSwift能代替Objective-C嗎?

    Swift能代替Objective-C嗎?

    這是我在網(wǎng)上上看到的答案,復(fù)制粘貼過(guò)來(lái)和大家分享一下,因?yàn)槲液秃芏嗳艘粯雍荜P(guān)心Swift的出現(xiàn)對(duì)Mac開(kāi)發(fā)的影響和對(duì)Objective-C的影響。...

    Swift教程網(wǎng)4412020-12-16
主站蜘蛛池模板: 97精品国产自在现线免费 | 国产成人永久免费视 | 国产成人在线播放 | 狠狠涩| 精品亚洲综合久久中文字幕 | 色五夜婷婷 | 国产特黄a级在线视频 | 暖暖 免费 高清 日本 中文 | 天天综合色网 | 韩国一级淫片特黄特刺激 | 国产精品色拉拉免费看 | 亚洲福利一区 | 免费看男女做好爽好硬视频 | 精品夜夜澡人妻无码AV蜜桃 | 欧美xingai | 19+韩国女主播激情vip视频在线 | 人妖欧美一区二区三区四区 | 91亚洲精品久久91综合 | 久久er国产免费精品 | 色橹 | 九九精品国产亚洲A片无码 九九99热久久999精品 | 国产女主播在线播放一区二区 | 日本欧美大码a在线视频播放 | 国产福利兔女郎在线观看 | 91手机看片国产永久免费 | 欧美人与禽杂交大片 | 国产精品久久久久网站 | pornohd老师18 | 欧美精品99久久久久久人 | 亚洲欧美另类综合 | 俄罗斯伦理片 | 国产三级精品三级男人的天堂 | 国产精品免费aⅴ片在线观看 | 91久久偷偷做嫩草影院免费看 | 午夜精品久视频在线观看 | 国产在线一区二区杨幂 | 国产麻豆剧果冻传媒观看免费视频 | 国产成人精品视频午夜 | 免费观看欧美性一级 | 二区三区视频 | 99视频一区 |