Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Demystify SwiftUI 要約 / Summary of Demystify Swi...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Elvis Shi
June 28, 2021
Programming
730
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Demystify SwiftUI 要約 / Summary of Demystify SwiftUI
Elvis Shi
June 28, 2021
More Decks by Elvis Shi
See All by Elvis Shi
@Environment(\.keyPath)那么好我不允许你们不知道! / atEnvironment keyPath is so good and you should know it!
lovee
0
450
ゼロから始めるPreferenceの実装 / Let's implement Preferences from scratch
lovee
0
150
Kotlin エンジニアへ送る:Swift 案件に参加させられる日に備えて~似てるけど色々違う Swift の仕様 / from Kotlin to Swift
lovee
1
390
個人アプリを2年ぶりにアプデしたから褒めて / I just updated my personal app, praise me!
lovee
0
730
How did I build an Open-Source SwiftUI Toast Library
lovee
1
170
SwiftUIで使いやすいToastの作り方 / How to build a Toast system which is easy to use in SwiftUI
lovee
3
1.3k
SwiftUIで二重スクロール作ってみた / When I tried to make a dual-scroll-ish view in SwiftUI
lovee
1
380
Observation のあれこれ / A brief introduction about Observation
lovee
3
440
ChatGPT 時代の勉強 / Learning under ChatGPT era
lovee
27
9k
Other Decks in Programming
See All in Programming
Lessons from Spec-Driven Development
simas
PRO
0
150
AIとRubyの静的型付け
ukin0k0
0
560
Modding RubyKaigi for Myself
yui_knk
0
910
OSもどきOS
arkw
0
480
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
150
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
390
AIエージェントの隔離技術の徹底比較
kawayu
0
470
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
100
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
190
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
530
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
200
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
13
3.6k
Featured
See All Featured
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
The Mindset for Success: Future Career Progression
greggifford
PRO
0
360
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
830
Optimizing for Happiness
mojombo
378
71k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Everyday Curiosity
cassininazir
0
230
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
860
Transcript
%FNZTUJGZ4XJGU6*ཁ f o r : 6 . & .
* T X J G U G F BU ) " , "5" T X J G U ʙ 8 8 % $ 3F DBQ ʙ
} var employedBy = "YUMEMI Inc." var job = "iOS
Tech Lead" var favoriteLanguage = "Swift" var twitter = "@lovee" var qiita = "lovee" var github = "el-hoshino" var additionalInfo = """ ΠψͰ͕͢ɺԿ͔ʁ """ final class Me: Developable, Talkable {
˞ೣͰྫΛ্͍͛ͯ·͕͢ɺൃදऀΠψͰ͢ɻ
࣌ؒ ҧ͏࣌ؒͷ ಉ͡ೣʁ
࣌ؒ ͦͦ ҧ͏ೣʁ
ࣸਅ͚ͩͰஅ͕Ͱ͖ͳ͍ w ҧ͏ೣͰͱͯࣅͯΔ͔͠Εͳ͍ w ಉ͡ೣͰ࣌ظʹΑͬͯݟ͕ͨҧ͏͔͠Εͳ͍ w அ͢ΔͨΊʹՃͷใ͕ඞཁ w ໊લ w
࠼ w FUD *EFOUJUZ
4XJGU6*Λཧղ͢ΔͨΊͷେϙΠϯτ w *EFOUJUZ w -JGFUJNF w %FQFOEFODZ 4XJGU6*͕͋ͳͨͷࢥ͏௨Γͷಈ࡞Λ͍ͯ͠ͳ͔ͬͨΒɺ େ͜ΕΒͷѻ͍͕ؒҧ͍ͬͯΔ͔Βɻ
*EFOUJUZ w େϙΠϯτͷதͰҰ൪ॏཁ w -JGFUJNF%FQFOEFODZɺ*EFOUJUZ͕͋Δ͔Β ͦ͜Γཱͭ w 4XJGU6*ʹछྨͷ*EFOUJUZ͕͋Δ w &YQMJDJU*EFOUJUZʢ໌ࣔత*%ʣ
w 4USVDUVSBM*EFOUJUZʢߏత*%ʣ
&YQMJDJU*EFOUJUZ w ಈతʹมΘΔϏϡʔʹɺ ΤϯδχΞ͕͚ͭΔ*% w ର͕Identifiable ʹద߹͍ͯ͠ͳ͍߹ *%ͷKeyPathΛࢦఆ ͢Δඞཁ͕͋Δ ForEach(cats,
id: \.name) { cat in Text("\(cat.age)ࡀ") } Explicit Identity
&YQMJDJU*EFOUJUZʹٻΊΒΕΔੑ࣭ w ϢχʔΫੑ w ଞͷରͱඃ͍ͬͯ ͚ͳ͍ w ෆมੑ w ͍ͭɺԿճݺͼग़ͯ͠
มΘ͍͚ͬͯͳ͍ ForEach(cats, id: \.name) { cat in Text("\(cat.age)ࡀ") } Explicit Identity
4USVDUVSBM*EFOUJUZ w ߏʹΑͬͯࣗಈతʹ ͚ΒΕΔ*% w JGจTXJUDIจͷذ ͕͋ͬͨΒҧ͏*%͕ ͚ΒΕΔ Structural Identity
if flag { Text("A") } else { Text("B") }
4USVDUVSBM*EFOUJUZͱͷ͖߹͍ํ w ಉ͡ϏϡʔͳΒɺذΛ ͯ͠ߦ͚ͳ͍ w ذΛͤͣʹ͏·͘ *OFSU.PEJ fi FSͳͲΛ ׆༻
Structural Identity if flag { Text("A") } else { Text("B") } ద༻ͯ͠ϏϡʔͷඳըʹӨڹ͠ͳ͍.PEJ fi FSɻ PQBDJUZ QBEEJOH FUD
ͳͥ*EFOUJUZ͕ॏཁ͔ w "OJNBUJPO͢Δͱ͖ͳͲͷஅࠜڌ w Ҡಈ͖͔͢ΫϩεϑΣʔυ͖͔͢ w Ϗϡʔͷ-JGFUJNFΛܾΊΔࠜڌ w ඞཁͳ͘ͳͬͨΒϝϞϦ͔Βফ͢
-JGFUJNF w 4XJGU6*ͷϏϡʔλΠϓܕ w ϏϡʔλΠϓͨͩͷϏϡʔඳըϨγϐ w ϏϡʔλΠϓͷΠϯελϯεࣗମඇৗʹ໋ w ͔͠͠Ϗϡʔͷੜଘظؒͬͱ͍ w
Ϗϡʔඞཁ͕͋ͬͨΒੜ͞Εɺඞཁͳ͘ͳͬͨΒফ͞ΕΔ w ੜ͞ΕͨΒonAppearɺফ͞ΕͨΒonDisappear͕ݺ ΕΔ w @State@StateObjectϏϡʔ͕ඞཁͳ͘ͳͬͨΒফ ͞ΕΔ
-JGFUJNF fl BHUSVF UBQ ࣌ؒ fl BHGBMTF struct Demo:
View { var flag: Bool var body: some View { if flag { Counter() .background(Color.blue) } else { Counter() .background(Color.red) } } } struct Counter: View { @State private var count = 0 var body: some View { Text("\(count)") .onTapGesture { count += 1 } } } fl BHUSVF ফ͞ΕΔ
-JGFUJNF fl BHUSVF UBQ ࣌ؒ fl BHGBMTF struct Demo:
View { var flag: Bool var body: some View { Counter() .background( flag ? Color.blue : Color.red ) } } struct Counter: View { @State private var count = 0 var body: some View { Text("\(count)") .onTapGesture { count += 1 } } } fl BHUSVF ফ͞Εͳ͍ Dependency
%FQFOEFODZ w %FQFOEFODZͨͩͷϏϡʔͷೖྗ w @State@StateObject͚ͩͰͳ͘ɺ @Bindingͨͩͷvarશͯ%FQFOEFODZ w bodyҎ֎શͯ%FQFOEFODZͱߟ͑ͯͳ͍ w %FQFOEFODZ͕มΘͬͨΒɺͦΕʹඥͮ͘Ϗϡʔ͕
࠶ඳը͞ΕΔ w CPEZ͕ݺΕ࣮ͯߦ͞ΕΔ
%FQFOEFODZ 7JFX 7JFX 7JFX 7JFX %FQFOEFODZ %FQFOEFODZ %FQFOEFODZ
·ͱΊ w *EFOUJUZΛ੍͢Δͷ4XJGU6*Λ੍͢Δ w -JGFUJNFΛҙ͠ͳ͍ͱඞཁͳঢ়ଶ͕ফ͑ͯ͠·͏ w %FQFOEFODZͰ࠷ඳը͢ΔϏϡʔΛநग़͍ͯ͠Δ
ࢀߟ IUUQTEFWFMPQFSBQQMFDPNWJEFPTQMBZXXED