zoukankan      html  css  js  c++  java
  • 关于“代理”(delegate)我的一点浅见

    代理就是你这个ViewController作为一个class本来不是干这个的,却要越俎代疱完成人家别的ViewController或者程序模块(比如 AVAudioPlayer)的功能,这时候就要用代理。

    比如View里面内置一个TableView,它View既要完成View的功能,也要完成TableView的功能,它就得是 UITableViewDelegate 和 UITableViewDataSource

    然后在 ViewDidLoad 里面,或者把 delegate 设置为 self (某某TableView.delegate = self) ,dataSource 设置为 self (某某TableView.dataSource = self);或者给tableView代码单独取一个文件名,dataSource代码单独取一个文件名。然后

    class TableViewController: UITableViewController {

            let myDataSource = MyTableViewDataSource(happyThings: ["Youtube", "Github", "Nucakola"], cellIdentifier: "cell")

            let myDelegate = MyTableViewDelegate()

            override func viewDidLoad() {

            。。。。。。

    }

    在另外的两个文件里:

    class MyTableViewDelegate: NSObject, UITableViewDelegate {

    }

    class MyTableViewDataSource: NSObject, UITableViewDataSource {

            var happyThings: [AnyObject]

            var cellIdentifier: String

            let header = "Happy Things"

            init(happyThings: [AnyObject]!, cellIdentifier: String!) {

                     self.happyThings = happyThings

                     self.cellIdentifier = cellIdentifier

            }

            func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

                     return HappyThings.count

            }

            func tableView(_ tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

                      let cell = tableview.dequeueReusableCell(withIdentifier: cellIdentifier, for: indexPath) as! UITableViewCell

                      // 提取对应行数据

                      let item = HappyThings[indexPath.row]

                      // 设置 cell

                      cell.textLabel?.text = item as? String

                      return cell

            }

    }

  • 相关阅读:
    快速挂载和分离VHD文件的小脚本
    开机自动挂载 VHD 的方法
    搭建属于你自己的RAMOS系统 – WIN7+VHD+GURB map方式
    去除右键的opendgl
    为XYplorer添加右键菜单:“使用XYplorer打开”
    用VB把xls转换为xlsx
    用VB把xlsx转换为xls
    把Excel工作簿的每个工作表提取出来保存为新工作簿
    (转载)uefi启动解析:由原理到实例
    理想中的SQL语句条件拼接方式 (二)
  • 原文地址:https://www.cnblogs.com/guozai9527/p/6373002.html
Copyright © 2011-2022 走看看