본문 바로가기

Programming

(141)
[SwiftUI] @StateObject 또는 @ObservedObject 차이점 SwiftUI에서 MVVM형태의 코드를 작성하려고 할때 아래와 같은 방식으로 대부분 사용할텐데요 class TestViewModel: ObservableObject { @Published var name: String? } struct TestView: View { @ObservedObject var viewModel = TestViewModel() var body: some View { Text(viewModel.name) } } ViewModel의 Property Wrapper에는 아래와 같이 @StateObject 또는 @ObservedObject를 지정할 수 있습니다. @StateObject var viewModel = TestViewModel() @ObservedObject var viewMod..
DEVIEW 2023 2일차 관람후기 안녕하세요 어제 오늘 코엑스 그랜드볼륨에서 진행된 DEIVEW 2023 2일차 관람 후기 전해드리고자 이렇게 왔습니다. 오랜만에 오프라인으로 진행되는 만큼 데뷰 티켓 오픈 했을 때부터 정말 치열했던 걸로 기억하는데요 저는 2일차 티켓을 얻게 돼서 다녀오게 됐습니다. 정말 코엑스 오랜만에 방문하네요 :) 오랜만에 방문하니까 더 느낌 색다른데요ㅎㅎ 입구에는 네이버Z, expert, whale, 웹툰 등 많은 네이버 서비스 홍보부스가 마련돼 있었는데요 각 부스마다 사람들이 이벤트 참여하기 위해 많이들 모여계셨더라고요 (저도 참가해볼까 했지만 줄이 너무 길어 그러진 못했어요ㅎㅎ) 다른 한쪽에는 쿠팡, 쏘카등 다른 IT회사들도 부스를 마련해서 자사 홍보를 하고 계셨어요 채용 문의 및 서비스 소개 등이 적극적으로 ..
Key path를 활용한 Swift Closure 활용하기 키 경로를 사용하여 코드를 더 읽기 쉽고 효율적으로 만드는 방법을 소개하도록 하겠습니다. 다음과 같이 회사의 이름 및 public 여부 등을 나타내는 Company struct가 있다고 해보겠습니다. struct Company { let name: String let isPublic: Bool let stockPrice: Int } let companies: [Company] = [ Company(name: "Apple", isPublic: true, stockPrice: 140), Company(name: "Facebook", isPublic: true, stockPrice: 12), Company(name: "Google", isPublic: false, stockPrice: 333), Company..
[WWDC2021] Your guide to keyboard layout 애플이 지난 WWDC2021에 이를 개선한 keyboardLayoutGuide를 발표했습니다. 그동안 키보드가 보여질때 나머지 View영역이 가려지는 걸 방지하기 위해 keyboardWillShowNotification등의 observer등을 통해 키보드가 올라올때, 또는 키보드가 내려갈 때 키보드 높이를 계산해 나머지 View Layout을 업데이트 해줘야하는 번거로움이 있었습니다. 이번에 새롭게 등장한게 바로 UIKeyboardLayoutGuide이라는 녀석입니다. 사용방법은 아래와 같습니다. (매우 심플해졌군요...) 키보드 높이에 영향받는 View가 있다면 keyboardLayoutGuide의 topAnchor을 통해 AutoLayout을 지정하면 됩니다. 아래 샘플은 버튼을 KeyboardLay..
구글시트를 사용하여 문자열 관리 방법 https://macgongmon.club/26 📱Google sheet를 사용해서 iOS 문자열을 관리해보자! 일반적으로 iOS에서 문자열 관리는 .strings 파일을 통해 관리를 하고 있다고 생각하고 있습니다. 하지만 프로젝트 디렉토리 안에 파일로 존재한다면 앱 내부의 문자열 수정은 반드시 개발자의 손 macgongmon.club https://twih1203.medium.com/ios-구글-스프레드-시트로-다양한-언어-localized-strings-만들고-적용-383745f41327 [iOS] 구글 스프레드 시트로 다양한 언어 Localized.strings 만들고 적용 에밀리입니다. twih1203.medium.com
withCheckedContinuation memory leak 현상 및 해결방법 Handler를 async/await으로 바꾸려는 경우 핸들러에 withCheckedContinuation를 추가해 아래와 같이 사용하는데요 Class MessageManager { func recentMessages() async -> [String] { return await withCheckedContinuation { continuation in self.requestMessages() { list in continuration.resume(returning: list) } } } } let messages = await recentMessages() 평상시에는 문제가 되지 않으나 만약 Class가 부득이하게 종료해야하는 상황이 오면, 기존에 요청했던 async를 모두 완료 되기 전에는 정상적으로..
[SwiftUI] @Published 사용법 및 @ObservedObject와의 관계 SwiftUI의 View 및 ViewModel 관계에서 주로 쓰는게 @Published와 @ObservedObject인데요 Class FooView { @ObservedObject viewModel = FooViewModel() } Class FooViewModel: ObservableObject { @Publihsed foo: String } 이들 관계 및 사용 관련해서 이해하기 좋은 블로그를 하나 소개하려 합니다. https://pilgwon.github.io/post/published-risks-and-usage-explained [수위프트UI/번역] 코드로 알아보는 @Published의 사용법과 위험성 @Published risks and usage explained with code exampl..
[SwiftUI] VStack과 LazyVStack과의 차이 VStack과 LazyVStack 또는 HStack과 LazyHStack 기본 요지는 - VStack은 전체 데이터를 메모리에 담아두고 스크롤 할때마다 보여줌 - LazyVStack은 데이터가 화면에 렌더링 되는 순간 보여지는 순간 그려짐 둘 차이만 봐도 메모리 차이가 심할 것 같아요 (미리 화면을 다 그려놓고 보여주느냐, 렌더링 되는 순간에 그려주느냐) 그럼 많이들 쓰는List는 어떤방식이냐? 궁금했는데요 https://developer.apple.com/forums/thread/651256 를 살펴보니 "List contents are always loaded lazily" List는 모두 Lazy하게 그려준다고 하니, 스크롤 형식의 많은 내용을 보여줄때는 List를 쓰면 될 것 같습니다. 참고사이트..

반응형