通訊錄

通訊錄(按照兩種不同的cell,按性別區分)

在ViewController.swift中鍵入:

在Main.storyboard中Editor->Embed in->Navigation Controller添加導航欄

import UIKit
enum Gender {
    case Boy
    case Girl
}
class Person {
    var gender:Gender! = nil
    var group:Character! = nil
    var name:String! = nil
    var phoneNumber:String! = nil
    var img:String! = nil
}

class ViewController: UIViewController,UITableViewDelegate,UITableViewDataSource {

    //全部的聯系人
    var dic:[Character :[Person]] = [Character:[Person]]()
    //聯系人的分組
    var sortArr:[Character] = [Character]()
    
    var tableView:UITableView? = nil
       override func viewDidLoad() {
        super.viewDidLoad()
        self.title = "通訊錄"
        self.tableView = UITableView(frame: self.view.bounds, style: .plain)
        self.tableView?.delegate = self
        self.tableView?.dataSource = self
        self.view.addSubview(self.tableView!)
        //注冊兩個cell(男和女)
        self.tableView?.register(ManTableViewCell.self, forCellReuseIdentifier: "Boy")
        self.tableView?.register(WomanTableViewCell.self, forCellReuseIdentifier: "Girl")
        
        //添加右上角的那個(“+”)
        let item = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(rightItem))
        self.navigationItem.rightBarButtonItem = item
        self.load()
        
    }
    //“+”的方法
    func rightItem() {
        let sec = SecondViewController()
        sec.operate = .Add
        weak var weakSelf = self
        sec.AddPersonBlock = {
            
            weakSelf?.insertPerson(p: $0)
            weakSelf?.tableView?.reloadData()
        }
        self.navigationController?.pushViewController(sec, animated: true)
    }
    //制造假數據(開始運行的時候不為空)
    func load(){
        let p = Person()
        p.name = "Liliy"
        p.phoneNumber = "456765"
        p.gender = .Girl
        p.group = "L"
        p.img = "person"
        insertPerson(p: p)
        
        let p1 = Person()
        p1.name = "Helen"
        p1.phoneNumber = "43565-4665"
        p1.gender = .Boy
        p1.group = "H"
        p1.img = "person"
        insertPerson(p: p1)
    }
    // 插入聯系人
    func insertPerson(p: Person) {
        // 根據聯系人的分組情況看大字典有沒有這個人的分組
        let groupArr = dic[p.group]
        if groupArr == nil { // 沒有這個分組
            // 創建一個分組
            var arr = [Person]()
            arr.append(p)
            // 把分組放在字典中
            dic[p.group] = arr
        } else { // 直接聯系人插入
            dic[p.group]?.append(p)
        }
        
        // 因為字典是無序的, 不能按照 a-z展示分組,所以要排序
        sortArr.removeAll()
        for item in dic.keys {
            sortArr.append(item)
        }
        // 排序
        sortArr.sort {
            return $0 < $1
        }
    }

    //返回多少行
    func numberOfSections(in tableView: UITableView) -> Int {
        return dic.keys.count
    }
    //返回多少組
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // 當前分組對應的key
        let group = sortArr[section]
        // 取出分組中的元素
        let arr = dic[group]
        // 返回元素的個數
        return (arr?.count)!
    }
    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 70
    }
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        // 取出person對象, 根據person對象確定使用哪種cell
        // 取出分組中的元素
        let group = sortArr[indexPath.section]
        let arr = dic[group]
        let p = arr?[indexPath.row]
        // 根據人判斷使用哪種cell
        if p?.gender == .Girl { // 女
            let   cell = tableView.dequeueReusableCell(withIdentifier: "Girl",for:indexPath) as! WomanTableViewCell
            
            cell.image2?.image = UIImage(named: (p?.img)!)
            cell.name?.text = p?.name
            cell.number?.text = p?.phoneNumber
            cell.backgroundColor = #colorLiteral(red: 0.4745098054, green: 0.8392156959, blue: 0.9764705896, alpha: 1)
            cell.accessoryType = .detailButton
            return cell
        } else { // 男
            let  cell = tableView.dequeueReusableCell(withIdentifier: "Boy",for:indexPath) as! ManTableViewCell
            cell.image1?.image = UIImage(named: (p?.img)!)
            cell.name?.text = p?.name
            cell.number?.text = p?.phoneNumber
            cell.backgroundColor = #colorLiteral(red: 0.501960814, green: 0.501960814, blue: 0.501960814, alpha: 1)
            cell.accessoryType = .detailButton
            return cell
        }
    }
    
    //分組標題
    func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        let group = sortArr[section]
        return "\(group)"
    }

    //點擊單元格
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        //先取出單元格對應的模型
        let group = sortArr[indexPath.section]
        let arr = dic[group]
        let p = arr?[indexPath.row]
        //傳遞到下一個界面
        let sec = SecondViewController()
        sec.operate = .Update
        sec.person = p
        sec.indexP = indexPath
        weak var weakSelf = self
        sec.UpdateBlock = {
            weakSelf?.dic[(weakSelf?.sortArr[$1.section])!]?[$1.row] = $0
            weakSelf?.tableView?.reloadData()
        }

        //推出下一個控制器
        self.navigationController?.pushViewController(sec, animated: true)
        
    }
}

command+n 創建一個Cocoa Touch Class 名為WomanTableViewCell.swift

import UIKit

class WomanTableViewCell: UITableViewCell {

    var name:UILabel! = nil
    var image2:UIImageView! = nil
    var number:UILabel! = nil
    
    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        
        self.name = UILabel(frame:CGRect(x: 90, y: 10, width: 100, height: 30))
        self.addSubview(self.name!)
        
        self.number = UILabel(frame: CGRect(x: 90, y: 30, width: 200, height: 40))
        self.addSubview(self.number!)
        
       self.image2 = UIImageView(frame: CGRect(x: 10, y: 20, width: 50, height: 40))
        self.addSubview(self.image2!)
            
    }
    
    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

}

command+n 創建一個Cocoa Touch Class 名為ManTableViewCell.swift

import UIKit

class ManTableViewCell: UITableViewCell {
    
    var name:UILabel! = nil
    var image1:UIImageView! = nil
    var number:UILabel! = nil

    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        
        self.name = UILabel(frame:CGRect(x: 100, y: 10, width: 200, height: 40))
        self.addSubview(self.name!)
        
        self.number = UILabel(frame: CGRect(x: 240, y: 10, width: 200, height: 40))
        self.addSubview(self.number!)
        
        self.image1 = UIImageView(frame: CGRect(x: 10, y: 20, width: 50, height: 40))
        self.addSubview(self.image1!)
    }
    
    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
    override func awakeFromNib() {
        super.awakeFromNib() 
    }

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

}

創建第二個ViewController名為SecondViewController

import UIKit

enum Do {
    case Add
    case Update
}

class SecondViewController: UIViewController {

    var nameTextField:UITextField! = nil
    var phoneTextField:UITextField! = nil
    var btn:UIButton! = nil
    
    var img:UITextField! = nil
    var genderTextField:UITextField! = nil
    var groupTextField:UITextField! = nil
    //記錄當前是更新還是添加
    var operate : Do! = nil

    //如果是更新傳遞過來一個對象
    var person:Person!=nil

    // 更新的閉包  1. p  2. 多少組,多少行
    var UpdateBlock: ((Person,IndexPath)->Void)? = nil
    
    // 添加的閉包 1. p
    var AddPersonBlock:((Person)->Void)? = nil
    // 更新時候P的下標
    var indexP: IndexPath? = nil
    override func viewDidLoad() {
        super.viewDidLoad()

        self.nameTextField = UITextField(frame: CGRect(x: 40, y: 100, width: 100, height: 40))
        self.nameTextField?.placeholder = "姓名"
        self.nameTextField?.borderStyle = .bezel
        
        self.view.addSubview(self.nameTextField!)
        
        self.phoneTextField = UITextField(frame: CGRect(x: 40, y: 200, width: 100, height: 40))
        self.phoneTextField?.placeholder = "電話"
        self.phoneTextField?.borderStyle = .bezel
        self.view.addSubview(self.phoneTextField!)
        
        self.img = UITextField(frame: CGRect(x: 40, y: 450, width: 100, height: 40))
        self.img?.placeholder = "顯示頭像"
        self.img?.borderStyle = .bezel
        self.view.addSubview(self.img!)
        
        self.genderTextField = UITextField(frame: CGRect(x: 40, y: 300, width: 100, height: 40))
        self.genderTextField?.placeholder = "性別"
        self.genderTextField?.borderStyle = .bezel
        self.view.addSubview(self.genderTextField!)
        
        self.view.backgroundColor = #colorLiteral(red: 0.9098039269, green: 0.4784313738, blue: 0.6431372762, alpha: 1)
        
        self.btn = UIButton(type: .system)
        self.btn?.frame = CGRect(x: 100, y: 500, width: 40, height: 30)
        self.btn?.addTarget(self, action: #selector(btnAction), for: .touchUpInside)
        self.btn?.setTitle("保存", for: .normal)
        self.view.addSubview(self.btn!)
        
        self.groupTextField = UITextField(frame: CGRect(x: 40, y: 380, width: 100, height: 40))
        self.groupTextField?.placeholder = "分組"
        self.groupTextField?.borderStyle = .bezel
        self.view.addSubview(self.groupTextField!)
        //判斷更新還是添加
        if self.operate == .Add { // 添加操作
            self.btn.setTitle("添加", for:.normal)
        } else { // 更新操作, 需要給textfield賦值
            self.btn.setTitle("更新", for: .normal)
            self.nameTextField.text = person.name
            self.phoneTextField.text = person.phoneNumber
            var str = ""
            str.append(person.group)
            self.groupTextField.text = str
            self.img.text = person.img
            // 性別
            if person.gender == .Girl {
                self.genderTextField.text = "女"
            } else {
                self.genderTextField.text = "男"
            }
            
        }
        
    }

    func btnAction(){
        
        // 不管添加還是更新, 都需要根據textfield創建一個對象傳遞到第一個界面
        let p = Person()
        p.name = self.nameTextField.text
        if self.genderTextField.text == "男" {
            p.gender = .Boy
        } else {
            p.gender = .Girl
        }
        p.phoneNumber = self.phoneTextField.text
        p.group = self.groupTextField.text?.characters[(self.groupTextField.text?.startIndex)!]
        p.img = "person"
        
        if self.operate == .Add { // 添加
            self.AddPersonBlock!(p)
        } else  { //更新
            self.UpdateBlock!(p,indexP!)
        }
    }
}

***運行結果如下圖



最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,763評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,238評論 3 428
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,823評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,604評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,339評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,713評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,712評論 3 445
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,893評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,448評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,201評論 3 357
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,397評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,944評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,631評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,033評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,321評論 1 293
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,128評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,347評論 2 377

推薦閱讀更多精彩內容