[1] ModelSerializer 개념 django rest framework의 ModelSerializer 에 대해 먼저 알아보겠습니다. ModelSerializer은 모델을 JSON으로 쉽게 바꿀 수 있도록 해주는 것입니다. 예를 들어 Account라는 모델이 있다고 할때 (문서에 모델 선언해둔 것은 없네요ㅠㅠ) AccountSerializer를 만들어서 내가 원하는 모델의 필드들만 json으로 만들어줄 수 있어요 모델의 모든 필드를 다 json으로 만들어줄 거라면 __all__ 을 해줄 수 도 있고 특정 필드만 제외하고 싶다면 exclude 해줄 수 도 있답니다. 그리고 nested json을 만들고 싶으면 depth 옵션을 사용할 수도 있습니다. (장고 튜토리얼과 다르게 장고 rest frame..
django-rest-framework 를 이용하여 restful API를 만들어보겠습니다. [1] 가상환경 만들기 (참고: [Django] 장고 설치하기(1) - 가상환경 세팅) conda create -n 가상환경이름 python=3.7 conda activate 가상환경이름 [2] django-rest-framework 패키지 설치하기 아래 명령어로 가상환경에 패키지를 설치해줍니다. pip install djangorestframework 설치가 완료된 후 아래 명령어를 해보세요-! pip list Django랑 djangorestframework가 같이 설치된 것을 볼 수 있습니다. (장고를 따로 설치안해줘도 되겠네요) [3] 프로젝트 생성하기 (참고: [Django] 튜토리얼 part 1 (1)..
곰튀김님의 Inversion 세션 (let us go summer 2020 => 2:18:19 쯤 나와요! 👍) 을 보다가 Dependency Container를 공부해보고자합니다. Dependency Injection의 개념 & SOLID의 D인 의존관계 역전 원칙(DIP)을 어떻게 따르게 해줄 수 있을지는 위의 세션 또는 이 글 을 참고해주세요 이 포스팅은 Dependency Container 또는 Dependecny Inject Container 또는 IOC Container (Inversion Of Control Container) 에 대해서만 살펴보겠습니다. [1] Dependency Container란 무엇인가?! 의존성 주입을 해줄때는 밖에서 인스턴스를 만들어서 주입해줍니다. (참고: 의존성..
Button은 딱 텍스트영역만 Tappable 하다. (노란색은 클릭영역이 아님) 이미지를 넣어도 마찬가지로 딱 이미지 영역만 Tappable하다. (노란색은 클릭영역이 아님) UIKit과 달리 SwiftUI에서는 버튼을 만들기 위해서 Label이라고 불리는 다른 뷰를 꼭 줘야한다.그래서 Label 영역만 tappable하게 디자인되었나보다. (추측) 그러면 Label말고 다른 영역도 Tappable하게 하려면 어떻게 해야할까?! [1] Button말고 Label에 frame을 주기 Label영역만 Tappable하니까 Label영역을 버튼사이즈로 해주면 되는 방법이다. [2] 버튼 아닌 뷰를 만든 후, onTapGesture 사용SwiftUI의 버튼이 Label 영역만 Tappable하게 디자인 되었다..
첫번째 사진의 modifier 순서는 background -> frame 입니다. 두번째 사진의 modifier 순서는 frame -> background 입니다. 결과가 다른 것을 볼 수있죠?! 그 이유는 무엇일까요-?! SwiftUI에서는 View에 modifier를 적용할때마다 새로운 view를 만들게 되는 것임을 기억해야합니다 (단지 존재하는 view의 속성을 바꾸는 게 아니라 새로운 view를 리턴하게 되는 것-!) 그래서 첫번째 사진은 아래와 같은 이유로 저렇게 그려졌고 두번째 사진은 아래와 같은 이유로 저렇게 그려졌습니다. 헷갈리지 않도록 frame modifier를 첫번째로 위치시켜야겠습니다...! 그리고 개발하면서 frame말고도 순서바꾸니까 원하는대로 동작했던 것이 또 있었는데 (잘 기..
[1] 문제 폰트 파일 Target Membership 설정도 해줬고 맥 OS > info.plist에 추가해야하는 값들도 추가했다. 근데 iOS에서는 커스텀 폰트가 잘먹는데, macOS에서만 안먹는 것이 아닌가...! [2] 해결 코드로는 ATSApplicationFontsPath . 맥 OS에서 커스텀 폰트를 쓰려면, info.plist에 ATSApplicationFontsPath이라는 키값을 추가해줘야한다. ATSApplicationFontsPath는 폰트파일이 어디 위치했는지 알려주는 역할을 한다. value값으로는 폰트파일의 location이나 폰트파일이 속한 directory를 알려주면 된다. (https://developer.apple.com/library/archive/documentati..
Future는 Publisher 프로토콜 을 conform하고 있다.Swift에서 asynchronous 프로그래밍을 위해 callback기반 completion handler를 사용했는데, (Rx안쓴다면)이제 Future를 사용하면 된다..! Future는 말그대로 아직 일어나지 않은 미래를 의미한다(??) Future는 Output과 Error를 가지고 있고 (Publisher를 conform하니까 당연쓰)final public class Future : Publisher where Failure : Error Promise 클로져가 있는데, Promise 클로져는 이렇게 생겼다. [1] 기본 사용법let future = Future { promise in promise(.success(..
[1] @State 이니셜라이저에서 state를 초기화해주려면 underscore를 써서 접근해야한다. (출처) struct SomeView: View { @State var selectedIndex: Int init() { let selectedInde = // do something _selectedIndex = State(initialValue: selectedIndex) } var body: some View { ... } } [2] @Binding 바인딩도 마친가지이다. 이니셜라이저에서는 underscore를 써서 접근해야한다 struct SomeView: View { @Binding var someValue: Int init(someValue: Binding) { _someValue = som..
[1] 다트의 함수 형태 리턴 타입과 파라미터 타입을 명시해줄 수도 생략해줄 수 도 있다. return을 => 로 대체할 수도 있다. bool isFood(String name) { return true; } isFood2(name) { return true; } isFood3(name) => true; return 타입을 생략한 경우 알아서 유추되지만, 파라미터 타입을 생략하면 dynamic 타입으로 되는 것을 알 수 있다. (dynamic은 어떤 타입이든 다 들어올 수 있음) [2] 다트의 파라미터 첫번째, 필수 O + 이름없는 parameter // required + not named parameter bool isFood(String name) { return true; } isFood("고기"..
- Total
- Today
- Yesterday
- 장고 URL querystring
- drf custom error
- 장고 Custom Management Command
- Flutter getter setter
- PencilKit
- 플러터 얼럿
- Django Firebase Cloud Messaging
- 구글 Geocoding API
- Sketch 누끼
- flutter dynamic link
- Flutter 로딩
- Flutter Clipboard
- cocoapod
- flutter deep link
- Watch App for iOS App vs Watch App
- METAL
- DRF APIException
- Dart Factory
- Flutter Spacer
- 플러터 싱글톤
- flutter 앱 출시
- ribs
- Django FCM
- Python Type Hint
- Django Heroku Scheduler
- SerializerMethodField
- ipad multitasking
- flutter build mode
- github actions
- Flutter Text Gradient
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |