1. UITabBarButtonItem 液态玻璃效果
兼容处理方案如下:
第一种方式(不推荐):关闭所有 UITabBarButtonItem 的液态玻璃效果。
if @available(iOS 26.0, *) {
self.navigationItem.rightBarButtonItem?.hidesSharedBackground = true
self.navigationItem.leftBarButtonItem?.hidesSharedBackground = true
} else {
// Fallback on earlier versions
}
第二种方式:所有导航栏按钮全部采用 UITabBarButtonItem,支持液态玻璃效果。
第三种方式:降低 Xcode 版本到 Xcode 25 及以下版本,然后再打包。
第四种方式:使用兼容模式显示传统 UI 风格,取消 TabBar 液态玻璃效果。 打开 Info.plist,添加一个 Boolean 键值对,添加完成后重新运行,UITabBar 恢复旧的样式:
<key>UIDesignRequiresCompatibility</key>
<true/>
2. UILayoutFittingExpandedSize 设置自定义 navigationItem.titleView 内容尺寸异常
在 iOS 26 上高度偏大,高度变为屏幕的高度,预期应为导航栏的高度。
原因:在 iOS 26 之前,UILayoutFittingExpandedSize 最大尺寸限制在导航栏范围内,而在 iOS 26 则允许充斥整个屏幕。
- (CGSize)intrinsicContentSize { return UILayoutFittingExpandedSize; }
兼容处理:修改 intrinsicContentSize,指定 titleView 的尺寸大小为导航栏大小。
#define SCREEN_WIDTH ([[UIScreen mainScreen] respondsToSelector:@selector(nativeBounds)] ? [UIScreen mainScreen].nativeBounds.size.width / [UIScreen mainScreen].nativeScale : [UIScreen mainScreen].bounds.size.width)
- (CGSize)intrinsicContentSize { return CGSizeMake(SCREEN_WIDTH, 44); }

