IOS:Swift:UITableView的編輯操作

AppDelegate.swift:
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
self.window = UIWindow(frame: UIScreen.main.bounds)
self.window?.backgroundColor = #colorLiteral(red: 0.2588235438, green: 0.7568627596, blue: 0.9686274529, alpha: 1)
self.window?.makeKeyAndVisible()
//創建導航視圖控制器的根視圖
let vc = RootTableViewController()
//2.創建導航視圖控制器,并為她制定根視圖控制器
let navigation = UINavigationController(rootViewController: vc)

    //3.將導航視圖控制器設置為window的根視圖控制器
    self.window?.rootViewController = navigation

    
    return true
}

RootTableViewController.swift
//不需要手動遵循協議和實現方法 RootTableViewController
/*
一、UITableViewController繼承自UIViewController,自帶一個tableview
二、self.view不是UIView而是UITableView
三、DataSource和delegate默認都是self(UITableViewController)
四、開發中只需要建立UITableViewController子類,就會幫我們實現datasource和delegate協議中一些相關方法,比如tableView編輯(增加/刪除、移動),以及多少分區,每個分區有多少cell和返回cell視圖的方法,當你需要的時候只需要打開相應的注釋即可
/
/

tableView編輯的步驟:
1.讓tableView處于編輯狀態
2.協議設定:
2.1設置那些cell可以編輯
2.2設置編輯樣式(插入刪除)
2.3提交編輯操作(1.先修改數據源2.更新UI)
/
/

tableView移動的步驟
1.讓tableView處于編輯狀態
2.設置哪些cell可以移動
3.提交移動結果(1.只需要更新數據源即可)
*/
class RootTableViewController: UITableViewController {

//        聯系人字典屬性    var dic:[String:[String]]  字典類型
var contactsource = [
    "w":["王哲磊","王浩","王樂","王晨陽"],"c":["陳揚","陳芮"],"b":["邊文達","寶音","白婧"],"l":["劉二蛋","劉婧","劉福宏","李玲"]]
//存放排好序的key值
var keysArray:[String]?
//重用標識
let identifier = "cell"
override func viewDidLoad() {
    super.viewDidLoad()
    
    //取出字典contactsource中的key
    let keys = self.contactsource.keys
    //,排序后賦值給keyArray
    keysArray = keys.sorted()

// print(keysArray!)

    //注冊限cell
    self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: identifier)
    
    
    
    
    
     self.navigationItem.rightBarButtonItem = self.editButtonItem
    
    
    
}
  override func numberOfSections(in tableView: UITableView) -> Int {
        // #warning Incomplete implementation, return the number of sections
        //分組個數=字典中鍵值對的個數
        //分組個數=存放排好序key值數組元素個數
        return contactsource.count
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // #warning Incomplete implementation, return the number of rows
        //先取出排好序key值數組中對應分區的key值
        let key = keysArray?[section]
        let group = contactsource[key!]
        
        return (group?.count)!
    }

   
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: identifier, for: indexPath)
//取出字典中key值對應數組元素的值賦值給textLabel
        //根據分區的下標取出key
        let key = keysArray?[indexPath.section]
        //根據key取出字典中的value。數組
        let group = contactsource[key!]
        //根據cell的下標取出數組對應位置的元素
        let name = group?[indexPath.row]
        cell.textLabel?.text = name
        
        return cell
    }
   
//頭部標題
    override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        return "\(keysArray![section])"
    }
    //添加右側索引列表
    override func sectionIndexTitles(for tableView: UITableView) -> [String]? {
        return keysArray
    }
 /* 2.設置哪些cell可以編輯*/
    // Override to support conditional editing of the table view.
    override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
        // Return false if you do not want the specified item to be editable.
        if indexPath.section < 2{
            return true
        }
        return false
    }
   //3。設置編輯樣式(插入/刪除)
    override func tableView(_ tableView: UITableView, editingStyleForRowAt indexPath: IndexPath) -> UITableViewCellEditingStyle {
        if indexPath.section == 0{
        return .delete
        }else if indexPath.section == 1{
        return .insert
        }
        return .none
    }
    /*4.提交編輯操作*/
    // Override to support editing the table view.
    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {

        //先取出選中cell所在的分區對應的key值
        let key = keysArray?[indexPath.section]
        //根據key值取出對應的value值數組
        var group = contactsource[key!]
//        print(group)
        
        if editingStyle == .delete {
            if group?.count == 1{
            //刪除整個分區
                //刪除字典中的鍵值對
                contactsource.removeValue(forKey: key!)
               //根據key值刪除索引欄   刪除排好序的
                keysArray?.remove(at: indexPath.section)
                //更新UI
                let set = NSIndexSet(index: indexPath.section)
                tableView.deleteSections(set as IndexSet, with: .left)
                
            }else{
                //一條一條的刪除cell
                //1.修改數據源
                group?.remove(at: indexPath.row)
                //          print(group)
                //            print(contactsource[key!])
                //刪除之后重新為key對應的value賦值
                contactsource[key!] = group
                
                //2.更新UI
                tableView.deleteRows(at: [indexPath], with: .fade)

            
            }
        
        
        } else if editingStyle == .insert {
            //準備要插入的數據
            let name = "小太陽"
            //先修改數據源
            group?.append(name)
            //重新為字典contactsource的鍵值對賦值
            contactsource[key!] = group
            //更新UI
            tableView.insertRows(at: [indexPath], with: .right)
            //4.讓tableView重新加載數據
            tableView.reloadData()

            
            
        }    
    }
    //2.設置哪些cell可以移動
    override func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
        // Return false if you do not want the item to be re-orderable.
        return true
    }
    
    
    /*3.提交移動的結果  */
     // Override to support rearranging the table view.
     override func tableView(_ tableView: UITableView, moveRowAt fromIndexPath: IndexPath, to: IndexPath) {
     //修改數據源
        //g
        let key = keysArray?[fromIndexPath.section]
        var group = contactsource[key!]
        //先取出數組中原位置的元素
        let name = group?[fromIndexPath.row]
        //刪除數組中原來位置的元素
        group?.remove(at: fromIndexPath.row)
        //在插入數組中新的位置
        group?.insert(name!, at: to.row)
        //從新對字典中key值對應的value值進行賦值
        contactsource[key!] = group
     }

    
    //限制跨分區移動
    /*sourceIndexPath移動之前cell的位置
     proposedDestinationIndexPath移動之后cell的位置
     command + option + /
     */
    /// 限制cell跨分區移動
    ///
    /// - Parameters:參數
    ///   - tableView: tableView對象 代理的委托人
    ///   - sourceIndexPath: 移動之前cell的位置
    ///   - proposedDestinationIndexPath: 移動之后cell的位置
    /// - Returns: 返回值cell移動之后最終的位置
    override func tableView(_ tableView: UITableView, targetIndexPathForMoveFromRowAt sourceIndexPath: IndexPath, toProposedIndexPath proposedDestinationIndexPath: IndexPath) -> IndexPath {
        //根據分區的下標判斷是否允許移動,當前后位置在同一個分區,允許移動,返回值移動之后的位置,當前后的位置不在同一個分區,不允許移動,返回移動之前的位置
        if sourceIndexPath.section == proposedDestinationIndexPath.section{
        return proposedDestinationIndexPath
        }else{
        return sourceIndexPath
        }
    }
    

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容