当前位置: > > > Swift - 第三方侧栏菜单组件SideMenu使用详解3(使用纯代码实现)

Swift - 第三方侧栏菜单组件SideMenu使用详解3(使用纯代码实现)

四、使用纯代码实现侧栏菜单

1,侧栏菜单的定义

我们继承 UITableViewController 来定义一个表格来作为侧栏菜单,表格内有三个单元格。
import UIKit

// 菜单视图控制器
class MenuViewController: UITableViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        //创建一个重用的单元格
        self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "myCell")
    }

    // 分区数
    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    // 单元格数量
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 3
    }

    // 返回单元格内容
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
        -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "myCell", for: indexPath)
        cell.textLabel?.text = "菜单\(indexPath.row + 1)"
        return cell
    }
}

2,侧栏菜单的使用

(1)主视图控制器中我们创建一个按钮,并在其点击响应中显示侧栏菜单。
import UIKit
import SideMenu

// 主视图控制器
class ViewController: UIViewController {
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // 创建一个按钮(点击后显示侧栏菜单)
        let button = UIButton(type:.system)
        button.frame = CGRect(x:40, y:100, width:150, height:30)
        button.setTitle("打开侧栏菜单", for:.normal)
        button.addTarget(self, action:#selector(tapped), for:.touchUpInside)
        self.view.addSubview(button)
        
        // 定义一个侧栏菜单
        let menu = UISideMenuNavigationController(rootViewController: MenuViewController())
        menu.isNavigationBarHidden = true //侧栏菜单不显示导航栏
        // 将其作为默认的右侧菜单
        SideMenuManager.default.menuLeftNavigationController = menu
    }
    
    // 按钮点击响应
    @objc func tapped(){
        // 显示侧栏菜单
        self.present(SideMenuManager.default.menuLeftNavigationController!, animated: true,
                     completion: nil)
    }
}

(2)运行结果如下:
  • 点击“打开侧栏菜单”按钮后,主视图会向右滑动,露出下方的侧栏菜单。
  • 侧栏菜单显示后,再次点击主视图(或者向左滑动屏幕)则会收起侧栏菜单。
  • 侧栏菜单无论是展开还是收起过程中,都会有动画效果。
             

3,使用右侧菜单

(1)如果想要实现右侧栏菜单,使用时只需做如下修改:
import UIKit
import SideMenu

// 主视图控制器
class ViewController: UIViewController {
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // 创建一个按钮(点击后显示侧栏菜单)
        let button = UIButton(type:.system)
        button.frame = CGRect(x:40, y:100, width:150, height:30)
        button.setTitle("打开侧栏菜单", for:.normal)
        button.addTarget(self, action:#selector(tapped), for:.touchUpInside)
        self.view.addSubview(button)
        
        // 定义一个侧栏菜单
        let menu = UISideMenuNavigationController(rootViewController: MenuViewController())
        menu.isNavigationBarHidden = true //侧栏菜单不显示导航栏
        // 将其作为默认的右侧菜单
        SideMenuManager.default.menuRightNavigationController = menu
    }
    
    // 按钮点击响应
    @objc func tapped(){
        // 显示侧栏菜单
        self.present(SideMenuManager.default.menuRightNavigationController!, animated: true,
                     completion: nil)
    }
}

(2)运行结果如下:
             

4,关闭侧栏菜单

如果想通过代码来关闭侧栏菜单,可以使用如下代码。
self.dismiss(animated: true, completion: nil)
评论0