Swift Combine — JUST Publisher

之前文章介绍的Publisher都是可以连续发送数据的,Subscriber也可以一直接收数据,除非收到了finished或者error而结束。而JUST Publisher则不同,它只向每个订阅者发送一次输出,然后结束。

一起来看一下下面的代码。

swift 复制代码
class JustViewModel: ObservableObject {

  func sendMessage() {
    let justPublisher = Just("This is a Just publisher")
    let cancellable = justPublisher
      .sink { completion in
        print("---> Received completion: \(completion)")
      } receiveValue: { value in
        print("---> Received value: \(value)")
      }
  }
}

struct JustDemo: View {

  @StateObject private var viewModel = JustViewModel()

  var body: some View {
    VStack {
      Button("Send Message") {
        viewModel.sendMessage()
      }
      .buttonStyle(BorderedProminentButtonStyle())
    }
  }
}

上面的代码中在JustViewModel中添加了一个方法sendMessage,在该方法里面创建了一个Just Publisher,创建的时候直接传入要发送的值,然后通过sink方法添加Subscriber

当在UI上点击按钮调用这个方法的时候,看一下输出:

很明显,点击后,初始化Just发送了初始化时的值,sink方法的receiveValue闭包调用了,随后也调用了Completion闭包,结束了这次事件流。

Just Publisher给任何一个Subscriber发送数据都只发送一次,然后就调用Completion

比如修改一下sendMessage方法,添加两次Subscriber

swift 复制代码
func sendMessage() {
  let justPublisher = Just("This is a Just publisher")

  // add first subscriber
  _ = justPublisher
    .sink { completion in
      print("---> Received completion: \(completion)")
    } receiveValue: { value in
      print("---> Received value: \(value)")
    }

  // add second subscriber
  _ = justPublisher
    .sink { completion in
      print("---> 2 Received completion: \(completion)")
    } receiveValue: { value in
      print("---> 2 Received value: \(value)")
    }
}

运行结果如下:

两次订阅的sink方法的回调都被调用了,而且每个Subscriber都只接收到一次数据,然后就调用Completion闭包了。

总的来说,Just Publisher还是比较简单,也比较好理解的。

最后,希望能够帮助到有需要的朋友,如果觉得有帮助,还望点个赞,添加个关注,笔者也会不断地努力,写出更多更好用的文章。

相关推荐
如此风景2 小时前
iOS SwiftUI开发所有修饰符使用详解
ios
mumuWorld2 小时前
KSCrash 实现机制深度分析
ios·源码阅读
AskHarries3 小时前
Google 登录问题排查指南
flutter·ios·app
崽崽长肉肉4 小时前
Swift中的知识点总结
ios·swift
2501_916007474 小时前
苹果手机iOS应用管理全指南与隐藏功能详解
android·ios·智能手机·小程序·uni-app·iphone·webview
代码不行的搬运工7 小时前
面向RDMA网络的Swift协议
开发语言·网络·swift
2501_915106327 小时前
全面理解 iOS 帧率,构建从渲染到系统行为的多工具协同流畅度分析体系
android·ios·小程序·https·uni-app·iphone·webview
TouchWorld9 小时前
iOS逆向-哔哩哔哩增加3倍速(1)-最大播放速度
ios·逆向
RollingPin9 小时前
React Native与Flutter的对比
android·flutter·react native·ios·js·移动端·跨平台开发
2501_916008899 小时前
iOS 能耗检测的工程化方法,构建多工具协同的电量分析与性能能效体系
android·ios·小程序·https·uni-app·iphone·webview