美文网首页ios-swift
ios开发-按拼音将城市分组

ios开发-按拼音将城市分组

作者: EgeTart | 来源:发表于2015-12-08 15:44 被阅读1854次

    ios开发-按拼音将城市分组

    新建一个工程,模版选择Single View Application.


    接下来对工程做一些初始配置
    1. 打开Main.storyboard,选中ViewController,把它嵌入到Navigation Controller中。
    2. 拖一个TableView到ViewController中,让它铺满整个ViewController中,点击右下角的Resolve Auto Layout Issues按钮,在弹出菜单中选择Add Missing Constraints。
    3. 选中刚刚添加的TableView,把它的Prototype Cells设置为1,并把Table View Cell的reused identifier设置为cell。


    4. 在Document Outline中选中Navigation Item把它的title改为"城市列表"。

      下面是以上步骤完成后的屏幕截图.

    接下来是代码部分

    1. 在storyboard中选中View Controller打开Assistant Editor为table View关联一个outlet,就叫做citysTableView好了。
    2. 打开ViewController.swift代码文件,在viewDidLoad()函数的上方添加一个叫做citys的城市数组。现在ViewController.swift代码文件的内容会和下面的代码段类似。
    import UIKit
    
    class ViewController: UIViewController {
        
        
        @IBOutlet weak var citysTableView: UITableView!
    
        let citys = ["北京市", "上海市", "天津市", "重庆市", "合肥市", "毫州市", "芜湖市", "马鞍山市", "池州市", "黄山市", "滁州市", "安庆市", "淮南市", "淮北市", "蚌埠市", "巢湖市", "宿州市", "六安市", "阜阳市", "铜陵市", "明光市", "天长市", "宁国市", "界首市", "桐城市", "广州市", "韶关市", "深圳市", "珠海市", "汕头市", "佛山市", "江门市", "湛江市", "茂名市", "肇庆市", "惠州市", "梅州市", "汕尾市", "河源市", "阳江市", "清远市", "东莞市", "中山市", "潮州市", "揭阳市", "云浮市", "昆明市", "曲靖市", "玉溪市", "保山市", "昭通市", "丽江市", "思茅市", "临沧市", "楚雄彝族自治州", "红河哈尼族彝族自治州", "文山壮族苗族自治州", "西双版纳傣族自治州", "大理白族自治州", "德宏傣族景颇族自治州", "怒江傈僳族自治州", "迪庆藏族自治州"]
        
        override func viewDidLoad() {
            super.viewDidLoad()
        
        }
    
    }
    

    3 在citys数组的下方定义两个变量,分别用来存储分组好的城市和每个组的标题。

    var cityGroups = [String: [String]]()
    var groupTitles = [String]()
    

    cityGroups变量是一个字典,每个key都是城市名的第一个字母,对应的值是以这个key开头的城市。

    4 现在定义一个方法,对城市按拼音的首字母进行分组。把这个方法添加到viewDidLoad()函数的下方。

    func makeCityToGroup() {
        // 遍历citys数组中的所有城市
        for city in citys {
            
            // 将中文转换为拼音
            let cityMutableString = NSMutableString(string: city)
            CFStringTransform(cityMutableString, nil, kCFStringTransformToLatin, false)
            CFStringTransform(cityMutableString, nil, kCFStringTransformStripDiacritics, false)
            
            // 拿到首字母作为key
            let firstLetter = cityMutableString.substringToIndex(1).uppercaseString
            
            // 检查是否有firstLetter对应的分组存在, 有的话直接把city添加到对应的分组中
            // 没有的话, 新建一个以firstLetter为key的分组
            if var value = cityGroups[firstLetter] {
                value.append(city)
                cityGroups[firstLetter] = value
            }
            else {
                cityGroups[firstLetter] = [city]
            }
        }
        
        //拿到所有的key将它排序, 作为每个组的标题
        groupTitles = cityGroups.keys.sort()
    }
    

    5 接着对扩展ViewController,让它遵循UITableViewDataSource和UITableViewDelegate这个两个协议。把下面的两段代码添加到最后一个花括号的下面。

    extension ViewController: UITableViewDataSource {
        
        func sectionIndexTitlesForTableView(tableView: UITableView) -> [String]? {
            return groupTitles
        }
        
        func numberOfSectionsInTableView(tableView: UITableView) -> Int {
            return cityGroups.count
        }
        
        func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            let firstLetter = groupTitles[section]
            return cityGroups[firstLetter]!.count
        }
        
        func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
            let firstLetter = groupTitles[indexPath.section]
            let citysInAGroup = cityGroups[firstLetter]!
            
            let cell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath)
            cell.textLabel!.text = citysInAGroup[indexPath.row]
            return cell
        }
    }
    
    extension ViewController: UITableViewDelegate {
        
        func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
            return groupTitles[section]
        }
    }
    

    这两段代码的作用还是非常直接明了的,就不写注释了。
    然后在viewDidLoad()函数的中添加下面的3句代码。

    citysTableView.dataSource = self
    citysTableView.delegate = self
        
    makeCityToGroup()
    

    是时候运行看下结果啦........
    最后上一张运行结果图。再附上demo地址

    相关文章

      网友评论

      本文标题: ios开发-按拼音将城市分组

      本文链接:https://www.haomeiwen.com/subject/bbpehttx.html