swift语言IOS8开发战记2.tableview

   上一章简单介绍了Swift写的button和alert,今天来学习一下tableview的用法。tableview看字面就知道,是列表组件。新建一个名为tableview的single view,步骤不罗嗦了。拖拽创建一个tableview,然后添加一个cell,prototype cells设为1,可以看到table中有一个cell。如图所示:

swift语言IOS8开发战记2.tableview

然后我们在代码中添加代码,想要在tableview中显示内容,需要一个数据源datasource,而数据源需要代理实现,只添加数据源还不够,需要添加数据源的方法,Xcode强大的代码不全给我们带来了很大的便利,比如我现在想要返回十行,只有一个组。代码如下:

import UIKit

class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {

  
    override func viewDidLoad() {
        super.viewDidLoad()
        let tableView = UITableView(frame: CGRectMake(0, 0, 320, 568), style: UITableViewStyle.Plain)
        self.view.addSubview(tableView)
        tableView.dataSource = self
        tableView.delegate = self
        // Do any additional setup after loading the view, typically from a nib.
    }
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
      return 10
        
    }

     func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 1;
    }
}



如果要在上面的行中增加内容,也就是添加cell的具体内容,添加以下方法:

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let identiString = "Cell"
        var cell = UITableViewCell(style: UITableViewCellStyle.Default, reuseIdentifier: identiString)
        cell.textLabel?.text = "cg Swift"
        return cell
    }
这个方法让每一行都输出一个“cg Swift”但是我们现在运行程序的话会发现tableview中是空的,那是因为我们没有把代码和显示关联起来。切换到图形页面中,不过这次的关联和第一话中的关联方法并不一样,不是把控件拖拽到代码中,而是右击tableview,把第一行中的datasource和delegate拖拽到tableview中,如图所示:

swift语言IOS8开发战记2.tableview

然后再运行,效果如下:

swift语言IOS8开发战记2.tableview


现在,我们来让tableview的内容变得复杂一点。声明一个数组,并且让tableview的每一行都显示数组的对应内容,点击后弹出提醒框,行数打印到控制台。代码如下:

import UIKit

class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {

    var restaurantNames = ["cg1","cg2","cg3","cg4","cg5","cg6","cg7","cg8","cg9","cg10","cg11"]
    override func viewDidLoad() {
        super.viewDidLoad()
        let tableView = UITableView(frame: CGRectMake(0, 0, 320, 568), style: UITableViewStyle.Plain)
        self.view.addSubview(tableView)
        tableView.dataSource = self
        tableView.delegate = self
        // Do any additional setup after loading the view, typically from a nib.
    }
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
      return restaurantNames.count
        
    }

     func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 1;
    }
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let identiString = "Cell"
        var cell = UITableViewCell(style: UITableViewCellStyle.Default, reuseIdentifier: identiString)
        cell.textLabel?.text = restaurantNames[indexPath.row]
       
        return cell
    }
    override func prefersStatusBarHidden() -> Bool { //隐藏上边栏中的电量、信号等信息
        return true
    }
    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        print(indexPath.row)
        var message = restaurantNames[indexPath.row]
        let alertView = UIAlertView(title: nil, message: message, delegate: nil, cancelButtonTitle: "Cancle")
        alertView.show()
    }
}

其中tableView.dataSource = self的意思是viewClntroller本身充当了tableview的数据源,注意此时我们手动添加viewController的一个集成UITableViewDelegate,这样可以不用去图形界面拖拽添加delegate,如果不添加的话,点击每一个cell是没反应的,tableView.datadelegate = self的设置,原理同datasource一样。 顺便温习了上一话中的知识,运行效果图如下:

swift语言IOS8开发战记2.tableview

上一篇:我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。


下一篇:【活动】Apache Flink文档翻译志愿者招募!