一. 導(dǎo)航欄 統(tǒng)一返回按鈕樣式
1.創(chuàng)建一個(gè)基類BaseViewController 繼承自UIViewController, 其余所有的ChildViewController都繼承自BaseViewController 在BaseViewController設(shè)置返回按鈕的樣式,代碼如下:
swift 版本:5.0
//去掉按鈕右邊的文字
navigationItem.backBarButtonItem = UIBarButtonItem.init(title: "", image:nil, primaryAction: nil, menu: nil)
//設(shè)置按鈕的顏色
navigationItem.backBarButtonItem?.tintColor = UIColor(red: 35 / 255, green: 35 / 255, blue: 35 / 255, alpha: 1.0)
以上代碼將就可以實(shí)現(xiàn)返回按鈕樣式統(tǒng)一
二. 自定義導(dǎo)航欄
1.設(shè)置導(dǎo)航欄透明
工作中經(jīng)常會遇到首頁無導(dǎo)航欄第二頁有導(dǎo)航欄這樣的情況,解決方法一般有兩種: 1.隱藏導(dǎo)航欄 2.設(shè)置導(dǎo)航欄透明 由于隱藏導(dǎo)航欄會導(dǎo)致一些特殊的效果,所以接下來介紹一下如何設(shè)置導(dǎo)航欄透明 同上在BaseViewController中添加代碼如下:
//設(shè)置導(dǎo)航欄按鈕為透明色圖片
navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
//設(shè)置導(dǎo)航欄陰影為透明色圖片
navigationController?.navigationBar.shadowImage = UIImage()
這樣導(dǎo)航欄就透明了,效果如下:

Simulator Screen Shot - iPhone 11 - 2021-06-12 at 16.52.21.png
但是這樣有個(gè)問題,所有的導(dǎo)航欄都會變透明,解決方案代碼如下:
func addNavBar(_ color:UIColor){
//設(shè)置導(dǎo)航欄高度(此處可根據(jù)導(dǎo)航欄高度的不同來獲取導(dǎo)航欄高度)
let size = CGSize(width: view.bounds.width, height: 91)
//純色創(chuàng)建UIImage
UIGraphicsBeginImageContextWithOptions(size, false, 0.0)
color.setFill()
UIRectFill(CGRect(origin: .zero, size: size))
let image = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
//將UIImage添加到UIImageView
let navImageView = UIImageView(image: image)
view .addSubview(navImageView)
}
在需要導(dǎo)航欄的頁面,調(diào)用方法如下:
override func viewDidLoad() {
super.viewDidLoad()
self.title = "第二頁"
//添加導(dǎo)航欄
addNavBar(.red)
}
效果如下圖:

Simulator Screen Shot - iPhone 11 - 2021-06-12 at 17.02.31.png