swift - iOS10后的自定义导航条按钮的偏移距离问题

在iOS10之前,自定义导航条按钮存在20像素的间隙问题,通常通过添加fixed.Space解决。然而,从iOS10开始,此方法失效。为应对这一变化,可以为按钮设置内容偏移,但可能引发响应区域问题。解决方法是为按钮类别添加分类,并应用相应代码调整。
摘要由CSDN通过智能技术生成

导航控制器是我们常用的控制器,在iOS10之前我们自定义的导航按钮在添加时会有为20个像素的间隙问题,通常的解决方式是创建一个类型为fixed..Space的item加入导航按钮组去解决间隙过大问题,但是但是在iOS10之后此方法就不在实用了!

如图:

之前的解决方式如下

lazy var leftButton:UIButton = {
        let button:UIButton = UIButton.init(frame: CGRect(x: 0, y: 0, width: 45, height: 45))
        button.setImage(UIImage(named: "left"), for: .normal)
//        /*向左进行偏移*/
        button.contentEdgeInsets = UIEdgeInsets(top: 0, left: -40, bottom: 0, right: 0)
        button.addTarget(self, action: #selector(actionLeft), for: .touchUpInside)
        return button
    }()

override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = UIColor.white

        let leftItem:UIBarButtonItem = UIBarButtonItem.init(cus
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值