通訊錄 <swift>

!!!!! 大手們請多多指教
今天試寫了一下通訊錄,有增加和刪除功能...邏輯上大致和OC相同,只是在語法上稍作改變。順序有些亂多包涵!!

首先先創建好會使用到得類:model類、工具類(用來管理一系列的操作)

// model類里面聲明兩個屬性
var name:String?
var number:String?

// 重寫初始化的方法
init(name:String,number:String) 
{
   super.init()
   self.name = name
   self.number = number
}
// 將工具類寫成一個單例
static let shareInstance:ModelTool = 
{
   let modeltool = ModelTool()
   return modeltool
}()

// 定義一個數組用來存放聯系人
var modelArray:[Model] = [Model]()

加載一個tableView做主界面,有導航欄和barBtn .barBtn實現點擊跳轉到 add頁面中

lazy var tableView:UITableView = {
  let tableView1 = UITableView(frame: UIScreen.mainScreen().bounds, style: UITableViewStyle.Plain)
  tableView1.delegate = self
  tableView1.dataSource = self
  return tableView1 
}()
// 加載 添加按鈕
lazy var leftBtn:UIBarButtonItem = {
        let leftBtn1 = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.Add, target: self, action: "addAction:")
        return leftBtn1
    }()
// 添加方法
func addAction(btn:UIBarButtonItem)
    {
        let AddVC = AddViewController()
        editBtn.title = "編輯"
        tableView.editing = false
        navigationController?.pushViewController(AddVC, animated: true)
    }

// 加載編輯按鈕
lazy var editBtn:UIBarButtonItem = {
        let editBtn1 = UIBarButtonItem(title: "編輯", style: UIBarButtonItemStyle.Plain, target: self, action: "editAction:")
        return editBtn1
    }()

// 編輯按鈕的兩個狀態下得不同功能
 func editAction(btn:UIBarButtonItem)
    {
        if (editBtn.title == "取消")
        {
            editBtn.title = "編輯"
            tableView.editing = false
        }
        else
        {
            editBtn.title = "取消"
            tableView.editing = true
        }
    }
 // 將按鈕添加到導航欄中
  navigationItem.leftBarButtonItem = leftBtn
  navigationItem.rightBarButtonItem = editBtn
````
因為要遵守協議,并且協議里面有必須實現的方法。直接寫一個延展用來實現協議方法,寫在 class外層
````
extension  ViewController:UITableViewDelegate,UITableViewDataSource{
// 返回cell,并且賦值. !!!不要忘記注冊(我省略了)
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell 
{
   // as! 是為了強制轉化
   let cell = tableView.dequeueReusableCellWithIdentifier("xx", forIndexPath: indexPath) as! ModelTableViewCell
   let  model = ModelTool.shareInstance.modelArray[indexPath.row]
   cell.modelConfigure(model)
   return cell

}
// 返回分區
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
{
     return  ModelTool.shareInstance.modelArray.count
}

// 刪除聯系人
func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath)
{ 
// 先操作數據源 再操作 UI
   ModelTool.shareInstance.modelArray.removeAtIndex(index.row)
   tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: UITableViewRowAnimation.Right)
}


}
````
自定義 cell,在里面加載相應的控件。我就不寫這些控件代碼了,直接寫給控件賦值的代碼
````
func modelConfigure(model:Model)
{
   nameL.text = model.name
   numberL.text = model.number
}
````
現在是添加頁面的代碼,控件代碼依舊不寫(兩個TextField,兩個Lable),在添加頁面中有一個add的btn。這里只寫btn的方法
````
 func addAction(btn:UIButton) {
        if (nameTF.text?.characters.count == 0)
        {
            return
        }
   // 添加一個 model,model的具體數據
        let model = Model(name: self.nameTF.text!,number: self.numberTF.text!)
   //  添加到model數組中
        ModelTool.shareInstance.modelArray.append(model)
        navigationController?.popViewControllerAnimated(true)
    }

````

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

推薦閱讀更多精彩內容