Skip to content
  • Home
  • Code
  • iOS & Swift
  • Combine
  • RxSwift
  • SwiftUI
  • Flutter & Dart
  • Tutorials
  • Art
  • Blog
Fx Studio
  • Home
  • Code
  • iOS & Swift
  • Combine
  • RxSwift
  • SwiftUI
  • Flutter & Dart
  • Tutorials
  • Art
  • Blog
Written by chuotfx on September 1, 2020

RxSwift – Hello world!

RxSwift

Contents

  • 1. Tham khảo
  • 2. Cài đặt RxSwift
  • 3. Sử dụng RxSwift bằng Playground
  • 4. Hello world!
  • Tóm tắt

Chào bạn đến với Fx Studio. Chúng ta lại tiếp tục với series RxSwift. Cuộc vui bây giờ mới bắt đầu mà thôi. Và trở ngại đầu tiên là cài đặt và chạy được chương trình đầu tiên.

Các bạn đã đi qua phần Giới thiệu khá là lèn nhèn và khó hiểu. Lời khuyên chân thành là bạn cũng đừng xa lầy vào đám lý thuyết hỗn độn đó. Tốt nhất là khi đi qua hết các kiến thức cơ bản thì hãy quay lại đọc nó. Khi đó bạn vừa ôn tập lại kiến thức cũ vừa hiểu kĩ hơn về bản chất. Cái này áp dụng cho đa số các kiến thức khác mà bạn tìm hiểu.

À, bắt đầu thôi!

1. Tham khảo

Trước tiên, bạn cần phải biết được một số trang của RxSwift và cộng đồng của nó.

  • Github: https://github.com/ReactiveX/RxSwift
  • Github họ hàng nhà Rx: https://github.com/ReactiveX
  • Cộng đồng: http://community.rxswift.org/
  • Github của tụi cộng đồng: https://github.com/RxSwiftCommunity

Và tất nhiên, Fx Studio cũng có một repo Github cho RxSwift. Tuy không xịn xò bằng, nhưng đó là nơi chứa code demo trong các bài viết của mình.

  • Checkout : https://github.com/fx-studio/rxswift_notes

2. Cài đặt RxSwift

Bạn truy cập vào link repo trên Github của RxSwift. Mình sẽ cài đặt thông qua CocoaPod. Bạn có thể đọc hết hướng dẫn trong repo kia cũng được, nhưng chỉ cần quan tâm tới đoạn Pod này thôi.

# Podfile
use_frameworks!

target 'YOUR_TARGET_NAME' do
    pod 'RxSwift', '~> 5'
    pod 'RxCocoa', '~> 5'
end

# RxTest and RxBlocking make the most sense in the context of unit/integration tests
target 'YOUR_TESTING_TARGET' do
    pod 'RxBlocking', '~> 5'
    pod 'RxTest', '~> 5'
end

Về RxSwift sẽ gồm 2 phần chính:

  • RxSwift dành cho ngôn ngữ Swift.
  • RxCocoa dành cho nền tảng iOS.

Ngoài ra, bạn cũng thấy Rx cũng len lỏi vào testing. Nhưng mà chúng ta tạm thời không cần quan tâm nhiều làm gì.

Tiếp theo, bạn tạo 1 project mới bằng Xcode. Sau đó tiến hành cài đặt CocoaPod lên project đó. Nếu bạn chưa biết CocoaPod là gì. Bạn hãy làm vài đường Google để được khai sáng.

Sau khi cài xong, bạn edit Podfile bằng đoạn pod ở trên và chạy lệnh pod install. Cuối cùng bạn mở project lên và tiến hành import RxSwift . Nếu như mà không báo lỗi gì hết, nghĩa là bạn đã cài đặt thành công rồi.

 

Giờ sang phần tiếp theo nào!

3. Sử dụng RxSwift bằng Playground

Các phần đầu tiên của series là đa số tập trung vào lý thuyết, nên Playground là công cụ thực hành nhanh nhất. Nhưng một điều ngăn cản là Playground không cài đặt RxSwift được. Mà các bạn dev thường rất ít khi tìm hiểu sâu hơn. Sau đây mình sẽ hướng dẫn luôn.

Mở file *.xcworkspace , do bạn đã tạo ra bằng việc pod init ở phần trên. Vì đã cài đặt RxSwift cho project đó rồi, nên chúng ta import về mặt thư viện trong Playground khá dễ dàng.

Bạn tiến hành New File > Playgournd. Điều chú ý ở đây chính là:

  • Nơi lưu file Playground là thư mục project.
  • Add to workspace & Group là project đó luôn để sử dụng được các thư viện đã cài đặt trong Project.

Và bạn cũng tiến hành import RxSwift vào file Playground đó. Nếu không có lỗi gì xãy ra tiếp, nghĩa là bạn tiếp tục cài đặt thành công thêm một bước nữa rồi. Còn nếu có lỗi, bạn hãy tắt Xcode đi và mở lại nó. 80% lỗi được khắc phục bằng cách đơn giản như vậy!

Bạn có thể xem qua về cấu trúc file của Workspace này. Lần sau, bạn muốn tạo thêm Playground khác để luyện tập về lý thuyết, thì cũng nên áp dụng cách tương tự này.

Tới đây, mình càng yêu quý Combine nhiều hơn. Vì nó cũng là họ hàng nhà Rx và nó được build sẵn vào trong core OS. Do đó, bạn có thể sử dụng mọi lúc mọi nơi, mà không cần phải rườm ra như thế này. Hàng chính chủ vẫn là xịn sò nhất.

4. Hello world!

Để tới được đây, bạn đã tốn công sức quá nhiều rồi. Chúng ta đi nhanh vào vấn đề chính nào. Bạn mở file HelloRx.playground và thêm đoạn code này vào.

let helloRx = Observable.just("Hello RxSwift")
    helloRx.subscribe { (value) in
        print(value)
}

Sau đó bấm thực thi Playground và xem kết quả.

next(Hello RxSwift)
completed

Nếu bạn chạy ra và kết quả đúng như vậy, thì chúc mừng bạn đã hoàn thành bài hôm nay. Còn mình sẽ giải thích sơ cho bạn hiểu như sau:

  • helloRx là 1 biến kiểu là Observable
  • Observable này là nguồn phát ra dữ liệu. Trong ví dụ, kiểu dữ liệu phát ra là String.
  • just là ám chỉ việc Observable này được tạo ra và phát đi 1 lần duy nhất, sau đó sẽ kết thúc.
  • Dữ liệu phát đi là chữ Hello RxSwift.
  • Để lắng nghe những gì mà helloRx phát ra thì bạn cần subscribe  tới nó.
  • Chúng ta cần cung cấp 1 closure để xử lý các giá trị nhận được từ nguồn phát.
  • Về giá trị nhận được
    • Sau khi, nguồn phát ra Hello RxSwift , nguồn sẽ tiếp tục phát ra tín hiệu kết thúc completed.

Okay! Tới đây, bạn đã hoàn thành được chương trình đầu tiên. Các phần vui còn rất nhiều ở các bài sau.

Tóm tắt

  • Cài đặt thư viện bằng CocoaPod.
  • Import vào Project & Playgound.
  • Thực hiện chương trình đầu tiên bằng Playground.

 

Okay! Tới đây, mình xin kết thúc bài viết về RxSwift – Hello world! trong RxSwift. Và nếu có gì thắc mắc hay góp ý cho mình thì bạn có thể để lại bình luận hoặc gởi email theo trang Contact.

  • Bài viết tiếp theo tại đây.

Cảm ơn bạn đã đọc bài viết này!

FacebookTweetPinYummlyLinkedInPrintEmailShares2

Related Posts:

  • testing
    Hello Testing iOS
  • Flutter
    Cài đặt Flutter SDK & Hello world
  • SwiftData
    SwiftData - Hello world!
Tags: rxswift
Written by chuotfx

Hãy ngồi xuống, uống miếng bánh và ăn miếng trà. Chúng ta cùng nhau đàm đạo về đời, về code nhóe!

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Donate – Buy me a coffee!

Fan page

Fx Studio

Tags

Actor Advanced Swift AI api AppDistribution autolayout basic ios tutorial blog ci/cd closure collectionview combine concurrency crashlytics dart dart basic dart tour Declarative delegate deploy design pattern fabric fastlane firebase flavor flutter GCD gradients iOS MVVM optional Prompt engineering protocol Python rxswift safearea Swift Swift 5.5 SwiftData SwiftUI SwiftUI Notes tableview testing TravisCI unittest

Recent Posts

  • Role-playing vs. Persona-based Prompting
  • [Swift 6.2] Raw Identifiers – Đặt tên hàm có dấu cách, tại sao không?
  • Vibe Coding là gì?
  • Cách Đọc Sách Lập Trình Nhanh và Hiệu Quả Bằng GEN AI
  • Nỗ Lực – Hành Trình Kiến Tạo Ý Nghĩa Cuộc Sống
  • Ai Sẽ Là Người Fix Bug Khi AI Thống Trị Lập Trình?
  • Thời Đại Của “Dev Tay To” Đã Qua Chưa?
  • Prompt Engineering – Con Đường Để Trở Thành Một Nghề Nghiệp
  • Vấn đề Ảo Giác (hallucination) khi tương tác với Gen AI và cách khắc phục nó qua Prompt
  • Điều Gì Xảy Ra Nếu… Những Người Dệt Mã Trở Thành Những Người Bảo Vệ Cuối Cùng Của Sự Sáng Tạo?

You may also like:

  • SwiftData - Hello world!
    SwiftData
  • Hello Testing iOS
    testing
  • Cài đặt Flutter SDK & Hello world
    Flutter

Archives

  • May 2025 (2)
  • April 2025 (1)
  • March 2025 (8)
  • January 2025 (7)
  • December 2024 (4)
  • September 2024 (1)
  • July 2024 (1)
  • June 2024 (1)
  • May 2024 (4)
  • April 2024 (2)
  • March 2024 (5)
  • January 2024 (4)
  • February 2023 (1)
  • January 2023 (2)
  • November 2022 (2)
  • October 2022 (1)
  • September 2022 (5)
  • August 2022 (6)
  • July 2022 (7)
  • June 2022 (8)
  • May 2022 (5)
  • April 2022 (1)
  • March 2022 (3)
  • February 2022 (5)
  • January 2022 (4)
  • December 2021 (6)
  • November 2021 (8)
  • October 2021 (8)
  • September 2021 (8)
  • August 2021 (8)
  • July 2021 (9)
  • June 2021 (8)
  • May 2021 (7)
  • April 2021 (11)
  • March 2021 (12)
  • February 2021 (3)
  • January 2021 (3)
  • December 2020 (3)
  • November 2020 (9)
  • October 2020 (7)
  • September 2020 (17)
  • August 2020 (1)
  • July 2020 (3)
  • June 2020 (1)
  • May 2020 (2)
  • April 2020 (3)
  • March 2020 (20)
  • February 2020 (5)
  • January 2020 (2)
  • December 2019 (12)
  • November 2019 (12)
  • October 2019 (19)
  • September 2019 (17)
  • August 2019 (10)

About me

Education, Mini Game, Digital Art & Life of coders
Contacts:
contacts@fxstudio.dev

Fx Studio

  • Home
  • About me
  • Contact us
  • Mail
  • Privacy Policy
  • Donate
  • Sitemap

Categories

  • Art (1)
  • Blog (44)
  • Code (11)
  • Combine (22)
  • Flutter & Dart (24)
  • iOS & Swift (102)
  • No Category (1)
  • RxSwift (37)
  • SwiftUI (80)
  • Tutorials (87)

Newsletter

Stay up to date with our latest news and posts.
Loading

    Copyright © 2025 Fx Studio - All rights reserved.