ModernMVVM 项目教程

ModernMVVM 项目教程

ModernMVVMA movie iOS app built with the MVVM architecture, Combine and SwiftUI frameworks https://www.vadimbulavin.com/modern-mvvm-ios-app-architecture-with-combine-and-swiftui/.项目地址:https://gitcode.com/gh_mirrors/mo/ModernMVVM

1. 项目的目录结构及介绍

ModernMVVM 项目的目录结构如下:

ModernMVVM/
├── ModernMVVM.xcodeproj
├── ModernMVVM
│   ├── App
│   │   ├── AppDelegate.swift
│   │   ├── SceneDelegate.swift
│   │   └── main.swift
│   ├── Models
│   │   └── Movie.swift
│   ├── ViewModels
│   │   └── MovieViewModel.swift
│   ├── Views
│   │   └── MovieView.swift
│   ├── Resources
│   │   └── Assets.xcassets
│   └── SupportingFiles
│       ├── Info.plist
│       └── LaunchScreen.storyboard
├── .gitignore
├── LICENSE
└── README.md

目录结构介绍

  • ModernMVVM.xcodeproj: Xcode 项目文件。
  • ModernMVVM: 主项目目录。
    • App: 包含应用程序的入口文件和生命周期管理文件。
      • AppDelegate.swift: 应用程序的委托文件,处理应用程序的生命周期事件。
      • SceneDelegate.swift: 处理多场景的生命周期事件(仅在 iOS 13 及以上版本使用)。
      • main.swift: 应用程序的入口点。
    • Models: 包含数据模型文件。
      • Movie.swift: 电影数据模型。
    • ViewModels: 包含视图模型文件。
      • MovieViewModel.swift: 电影视图模型,处理数据逻辑。
    • Views: 包含视图文件。
      • MovieView.swift: 电影视图,展示电影数据。
    • Resources: 包含资源文件。
      • Assets.xcassets: 图片和其他资源的集合。
    • SupportingFiles: 包含支持文件。
      • Info.plist: 应用程序的配置文件。
      • LaunchScreen.storyboard: 启动屏幕的界面文件。
  • .gitignore: Git 忽略文件配置。
  • LICENSE: 项目许可证文件。
  • README.md: 项目说明文档。

2. 项目的启动文件介绍

AppDelegate.swift

AppDelegate.swift 是应用程序的委托文件,负责处理应用程序的生命周期事件,如启动、进入后台、恢复到前台等。

import UIKit

@main
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // 应用程序启动后的初始化代码
        return true
    }

    // 其他生命周期方法...
}

SceneDelegate.swift

SceneDelegate.swift 处理多场景的生命周期事件,仅在 iOS 13 及以上版本使用。

import UIKit

class SceneDelegate: UIResponder, UIWindowSceneDelegate {

    var window: UIWindow?

    func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
        // 使用此方法配置和附加到提供的窗口场景
        guard let _ = (scene as? UIWindowScene) else { return }
    }

    // 其他生命周期方法...
}

main.swift

main.swift 是应用程序的入口点,负责启动应用程序。

import UIKit

UIApplicationMain(
    CommandLine.argc,
    CommandLine.unsafeArgv,
    nil,
    NSStringFromClass(AppDelegate.self)
)

3. 项目的配置文件介绍

Info.plist

Info.plist 是应用程序的配置文件,包含应用程序的各种配置信息,如应用程序的显示名称、版本号、权限声明等。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>CFBundleDevelopmentRegion</key>
    <string>en</string>
    <key>CFBundleDisplayName</key>
   

ModernMVVMA movie iOS app built with the MVVM architecture, Combine and SwiftUI frameworks https://www.vadimbulavin.com/modern-mvvm-ios-app-architecture-with-combine-and-swiftui/.项目地址:https://gitcode.com/gh_mirrors/mo/ModernMVVM

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

马安柯Lorelei

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值