当前位置: 首页 > news >正文

iOS 如何自定义第一个显示的视图(含 SceneDelegate 删除指南) - 详解

iOS 如何自定义第一个显示的视图(含 SceneDelegate 删除指南) - 详解

一. 引言

在刚创建一个 iOS 工程时,Xcode 会默认生成一个简单的 ViewController 并把它作为 App 启动后展示的第一个页面。但在真实项目中,我们往往需要:

  • 使用 TabBar 作为首页
  • 使用导航控制器包裹首页
  • 动态选择首页(引导页 / 登录页 / 主页面)
  • 使用自己的 AppDelegate 完成初始化逻辑(路由、主题、依赖注入等)

这篇文章就以 真实项目结构 为例,完整讲一下:

  1. 如何在 AppDelegate 中自定义第一个展示页面
  2. 为什么会出现 SceneDelegate
  3. 如何在包含 SceneDelegate 的项目中设置首页
  4. 如果你不需要 SceneDelegate —— 如何“完全移除”它,让项目更简单

二. 移除原根视图控制器

通常来讲ViewController很难满足项目需求,那么第一件事儿应该就是想办法删除这个原来的根视图控制器。

我们可以在左侧文件中找到Main.storyboard,会发现有一个小箭头指向这个ViewController,我们使用鼠标选中小箭头按删除键,即可移除原来的根视图。

三. AppDelegate

其实在iOS13之前,所有的事情都是在AppDelegate中完成的,AppDelegate的代码如下:

@main
class AppDelegate: UIResponder, UIApplicationDelegate {func application(_ application: UIApplication,didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {return true}...
}

这是最简单也最容易理解的结构:AppDelegate是整个App的入口,我们可以在这里自己手动创建window,自定义设置根视图控制。

例如一个实际项目的AppDelegate代码如下:

@main
class AppDelegate: UIResponder, UIApplicationDelegate {var window: UIWindow?func application(_ application: UIApplication,didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {setupMain()return true}/// 设置 mainprivate func setupMain() {window = UIWindow(frame: UIScreen.main.bounds)let tabBarController = GZTabBarController()let nav = UINavigationController(rootViewController: tabBarController)nav.setNavigationBarHidden(true, animated: false)window?.rootViewController = navwindow?.makeKeyAndVisible()}
}

这种写法极为常见:

  • 手动创建 UIWindow
  • 手动设置 rootViewController
  • 你可以根据业务决定展示 TabBar / 登录页 / 引导页等任意界面

四. SceneDelegate

iOS 13之后多了一个 SceneDelegate,主要是因为iOS 13发布了多窗口(Multiple Scenes)机制,也就是在 iPad 上可以让一个 App 打开多个窗口。

因此苹果新增了 SceneDelegate,用于管理每一个窗口:

application → 多个 scene → 每个 scene 对应一个 UIWindow

所以新工程里你会看到:

  • AppDelegate 不再负责 window
  • SceneDelegate 接管 window 与 rootViewController

4.1 如果你的项目包含 SceneDelegate:那该怎么自定义首页?

就目前来我们能用xcode版本创建的项目必然包含SceneDelegate,但是也不需要慌,只需要把 AppDelegate 的 setupMain() 移到 SceneDelegate:

func scene(_ scene: UIScene,willConnectTo session: UISceneSession,options connectionOptions: UIScene.ConnectionOptions) {guard let windowScene = (scene as? UIWindowScene) else { return }window = UIWindow(windowScene: windowScene)let tabBar = GZTabBarController()let nav = UINavigationController(rootViewController: tabBar)nav.setNavigationBarHidden(true, animated: false)window?.rootViewController = navwindow?.makeKeyAndVisible()
}

但是 如果你的项目需要再iOS 13以下的系统中运行,那么AppDelegate中的代码也不能省略。

4.2 但是很多 iPhone App 根本不需要 SceneDelegate —— 可以删除吗?可以!

绝大部分 iPhone 应用并不会用到 iPad 的多窗口,所以 SceneDelegate 完全是累赘。如果你希望项目保持最简单的 AppDelegate + Window 模式,只需要:

删除 SceneDelegate.swift 文件

直接从项目中删掉。

删除 Info.plist 里的 Scene 配置

Application Scene Manifest → UIApplicationSceneManifest

删掉后 App 就不会再尝试创建 Scene 了。

让 AppDelegate 恢复为 window 模式

然后就是把AppDelegate 还当做APP入口,在 didFinishLaunchingWithOptions 中设置 rootViewController。

此时项目就回到最简单、最稳定的结构:AppDelegate 100% 负责。

五. 结语

无论使用哪种结构,都记住一句话:

第一个界面 = window.rootViewController,window 的创建者是谁 → 首页入口就写在哪里。

项目结构

首页入口位置

不含 SceneDelegate

AppDelegate 的 didFinishLaunchingWithOptions

含 SceneDelegate

SceneDelegate 的 scene(_:willConnectTo:)

删除 SceneDelegate

又回到 AppDelegate

在真实项目中,我们一般会:

  • 使用 UINavigationController 包裹 TabBar
  • 隐藏导航栏,由业务统一管理导航样式
  • 为后续引导页 / 登录页 / 路由切换留出空间

这也是大量上线应用的通用写法。

http://www.jsqmd.com/news/109528/

相关文章:

  • AI Agent文档生成效率翻倍的秘密:5个你不知道的部署优化技巧
  • LeaguePrank深度解析:LOL游戏形象定制技术完全指南
  • 手把手教你搭建MCP MS-720 Agent调试环境:99%新手忽略的关键步骤
  • 英雄联盟皮肤修改神器R3nzSkin:三步解锁全英雄付费皮肤
  • 4、编码过程中的调试技巧
  • 为什么选择Kotaemon?模块化RAG架构的优势分析
  • 超声波分散机知名品牌有哪些,哪个品牌口碑好?2025年度排行榜 - 品牌推荐大师
  • MCP Azure量子监控实战指南(企业级监控架构设计)
  • GitStats统计工具:全方位Git仓库分析实践指南
  • Lenovo Legion Toolkit终极故障排除手册:20个常见问题一步到位解决方案
  • 为什么你的AI Agent扛不住流量洪峰?5个真实压测案例告诉你真相
  • 【MCP Azure量子监控全攻略】:掌握五大核心工具提升系统稳定性
  • 5、Win32调试器深度解析
  • Kotaemon中的热点数据预加载机制提升响应
  • GIF流畅度提升终极指南:Waifu2x完整使用教程
  • MuJoCo无头渲染解决方案:EGL环境配置与MjrContext实战技巧
  • Flow Launcher文件替换异常终极解决方案:从诊断到加固的完整实战指南
  • Unity包快速解压完全指南:告别Unity编辑器的束缚
  • 【限时干货】AI Agent文档生成部署实战:从环境搭建到上线监控
  • 揭秘MCP Azure量子监控难题:3大工具助你实现毫秒级响应
  • 3分钟掌握B站黑名单管理:告别烦人弹幕的终极指南
  • GESP认证C++编程真题解析 | B3869 [GESP202309 四级] 进制转换
  • 6、Visual Studio .NET 调试器高级使用指南
  • 零信任架构下的权限革命:MCP PL-600 Agent四级权限落地指南
  • 你真的会用Azure Monitor吗?,AZ-500云Agent集成配置全揭秘
  • 手把手教你构建安全合规的MCP PL-600 Agent权限体系,错过等于隐患
  • 系统性能优化实践指南:从基础配置到高级调优
  • MCP续证在即,最后3个名额锁定权威培训资源
  • 别再烧钱了!Azure量子计算成本优化的7个关键检查点
  • Delphi逆向工程完整解决方案:高效恢复源代码的专业指南