zoukankan      html  css  js  c++  java
  • Swift

    像iOS中的通讯录,通过点击联系人表格右侧的字母索引,我们可以快速定位到以该字母为首字母的联系人分组。
     
    要实现索引,我们只需要两步操作:
    (1)实现索引数据源代理方法
    (2)响应点击索引触发的代理事件

    效果图如下:


    代码如下:
    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    import UIKit
     
    class ViewController: UIViewController , UITableViewDelegate, UITableViewDataSource{
         
        var tableView:UITableView?
         
        var adHeaders:[String] = ["a","b","c","d","e"]
         
        override func loadView() {
            super.loadView()
        }
         
        override func viewDidLoad() {
            super.viewDidLoad()
             
            //创建表视图
            self.tableView = UITableView(frame:UIScreen.mainScreen().applicationFrame,
                style:UITableViewStyle.Grouped)
            self.tableView!.delegate = self
            self.tableView!.dataSource = self
            //创建一个重用的单元格
            self.tableView!.registerClass(UITableViewCell.self, forCellReuseIdentifier: "SwiftCell")
            self.view.addSubview(self.tableView!)
        }
         
        //实现索引数据源代理方法
        func sectionIndexTitlesForTableView(tableView: UITableView) -> [AnyObject]! {
            return adHeaders
        }
         
        //点击索引,移动TableView的组位置
        func tableView(tableView: UITableView, sectionForSectionIndexTitle title: String,
            atIndex index: Int) -> Int {
            var tpIndex:Int = 0
            //遍历索引值
            for character in adHeaders{
                //判断索引值和组名称相等,返回组坐标
                if character == title{
                    return tpIndex
                }
                tpIndex++
            }
            return 0
        }
         
        //设置分区数
        func numberOfSectionsInTableView(tableView: UITableView!) -> Int {
            return adHeaders.count;
        }
         
        //返回表格行数
        func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return 5
        }
         
        // UITableViewDataSource协议中的方法,该方法的返回值决定指定分区的头部
        func tableView(tableView:UITableView, titleForHeaderInSection
            section:Int)->String
        {
            var headers =  self.adHeaders;
            return headers[section];
        }
         
        //设置分组尾部高度(不需要尾部,设0.0好像无效)
        func tableView(tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat {
            return 0.1
        }
         
        //创建各单元显示内容(创建参数indexPath指定的单元)
        func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath)
            -> UITableViewCell
        {
            //为了提供表格显示性能,已创建完成的单元需重复使用
            let identify:String = "SwiftCell"
            //同一形式的单元格重复使用,在声明时已注册
            let cell = tableView.dequeueReusableCellWithIdentifier(identify, forIndexPath: indexPath)
                as UITableViewCell
            cell.accessoryType = UITableViewCellAccessoryType.DisclosureIndicator
            var secno = indexPath.section
            cell.textLabel?.text = self.adHeaders[secno]+String(indexPath.item)
            return cell
        }
         
        override func didReceiveMemoryWarning() {
            super.didReceiveMemoryWarning()
        }
    }
  • 相关阅读:
    把VB.NET代码转换为C#代码的方法
    离散数学 第二章 谓词逻辑 26 前束范式
    离散数学 第二章 谓词逻辑 27 谓词演算的推理理论
    asp.net中怎样用Javascript控制RequiredFieldValidator控件什么时候启用,什么时候不启用验证?
    离散数学中的IFF标记
    BIRT Overview
    离散数学 第二章 谓词逻辑 25 谓词演算的等价式和蕴涵式
    getRemoteAddr()和getRemoteHost()的区别
    scp 不用密码
    利用spring实现javamail功能
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/4843320.html
Copyright © 2011-2022 走看看