前端学SwiftUI第1篇:入口逐行分析

SwiftUI官方文档

一、前置条件

  • 下载xcode
  • 创建一个app项目,创建完长这样的

二、目录结构

这里我创建的一个名字叫HelloWorld的项目

css 复制代码
HelloWorldApp.swift 入口文件,可以理解成main.js
ContentView.swift   可以理解成 App.vue
Assets.xcassets     放图片静态资源的,类似vue里的assets文件夹

另外两个测试的文件夹我们就先不管了

三、HelloWorldApp.swift 入口文件main.js

swift 复制代码
import SwiftUI

@main 
struct HelloWorldApp: App {
    var body: some Scene {
        WindowGroup {
            ContentView()
        }
    }
}
  • import SwiftUI:不引入Swift编译器没有办法理解你下面写的内容是什么。
  • @main: 标记告诉编译器 HelloWorldApp 是您的应用程序的入口点,从而使得 SwiftUI 应用程序能够正确初始化并运行。
  • struct 是声明结构体的关键字
  • App是一个协议,用于定义应用程序的行为以及配置应用程序的外观和行为,应该也可以理解成类似TS里面的类型
  • var body 类似于html中的body标签
  • some Scene 是一个不透明类型的表示。它被用于表示应用程序的场景,通常在应用程序的入口点中用作返回类型。
  • WindowGroup 是一种用于表示应用程序窗口的 container 类型。它用于创建应用程序的主窗口,并指定该窗口的内容。通常情况下,您可以将应用程序的根视图作为 WindowGroup 的内容。
  • ContentView 可以理解成隐式引入了一个组件,swift这里有点奇怪不需要引入就直接用了,这个其实就是调用了ContentView.swift里的组件。

四、ContentView.swift 入口布局文件-App.vue

swift 复制代码
import SwiftUI

struct ContentView: View { // 这个就是入口文件调用过的
    var body: some View { //理解成html的body标签
        VStack {  //理解成html标签,VStack是从上往下,HStack是从左往右
            Image(systemName: "globe") //这个图标不知道哪里来的,感觉是UI里有自带的图标
                .imageScale(.large)
                .foregroundStyle(.tint)
            mage("man") //这是我自己加的代码,向Assets.xcassets拖了一个图片进去
                .resizable()
                .frame(width: 60, height: 60) //指定大小
            Text("Hello, world!")  //文本
        }
        .padding() //这里是padding是0的意思
    }
}

//这个东西比较特殊,前端肯定没有见过,它是加了之后右边才会有预览的功能
#Preview {
    ContentView()
}

感谢🙏阅读,ios的大佬们见笑了😂,如果有看到欢迎指点一下

相关推荐
layman05281 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔1 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN2 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒2 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库2 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_180079052472 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
晓晓莺歌2 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
Up九五小庞2 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
qq_177767373 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos