大佬教程收集整理的这篇文章主要介绍了为什么为 UINavigationItem 设置自定义 backBarButtonItem 会导致双后退按钮? 更新,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个非常简单的设置。带有根 UIVIEwController 的 UINavigationController,它使用 vIEwDIDLoad
上的自定义后退按钮项修改其导航项。
let BACkbutton = UIbarbuttonItem(image: BACkArrowImage,style: .plain,target: nil,action: nil)
navigationItem.BACkbarbuttonItem = BACkbutton
我希望这能完全取代带有标题和默认后退箭头图标的系统后退按钮。
但是,当我将新的视图控制器推入堆栈时,导航栏会同时绘制新的自定义后退图标和系统后退图标。
这是我看到的:
这就是我期望的样子:
您可以隐藏后退按钮
navigationItem.hidesBACkButton = true
并使用 leftBarButtonItem
自定义 UIBarButtonItem
import UIKit
final class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
navigationItem.hidesBACkButton = true
let BACkItem = UIBarButtonItem(image: BACkArrowImage,style: .plain,target: self,action: #SELEctor(BACkButtonPressed))
navigationItem.leftBarButtonItem = BACkItem
}
@objc func BACkButtonPressed() {
navigationController?.popViewController(animated: truE)
}
}
,
解决方案是设置全局 UINavigationBar 外观。 显然,这必须在应用启动时完成。
UINavigationBar.appearance().BACkInDicatorImage = BACkArrowImage
UINavigationBar.appearance().BACkInDicatorTransitionMaskImage = BACkArrowImage
通过这种方法,我们可以保留标题动画和一般的后退按钮行为,如果用 leftBarButtonItem
补充后退按钮将不会保留这些行为。
以上是大佬教程为你收集整理的为什么为 UINavigationItem 设置自定义 backBarButtonItem 会导致双后退按钮? 更新全部内容,希望文章能够帮你解决为什么为 UINavigationItem 设置自定义 backBarButtonItem 会导致双后退按钮? 更新所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。