惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

S
Schneier on Security
有赞技术团队
有赞技术团队
T
The Blog of Author Tim Ferriss
F
Fortinet All Blogs
D
DataBreaches.Net
F
Full Disclosure
腾讯CDC
博客园 - 【当耐特】
MyScale Blog
MyScale Blog
Stack Overflow Blog
Stack Overflow Blog
小众软件
小众软件
Hugging Face - Blog
Hugging Face - Blog
Last Week in AI
Last Week in AI
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
爱范儿
爱范儿
The GitHub Blog
The GitHub Blog
Engineering at Meta
Engineering at Meta
大猫的无限游戏
大猫的无限游戏
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
SegmentFault 最新的问题
The Register - Security
The Register - Security
WordPress大学
WordPress大学
博客园 - 聂微东
雷峰网
雷峰网
J
Java Code Geeks
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
P
Privacy International News Feed
酷 壳 – CoolShell
酷 壳 – CoolShell
A
Arctic Wolf
Scott Helme
Scott Helme
C
Cyber Attacks, Cyber Crime and Cyber Security
T
Tor Project blog
博客园 - 三生石上(FineUI控件)
Know Your Adversary
Know Your Adversary
AWS News Blog
AWS News Blog
G
Google Developers Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CERT Recently Published Vulnerability Notes
O
OpenAI News
Project Zero
Project Zero
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Application and Cybersecurity Blog
Application and Cybersecurity Blog
云风的 BLOG
云风的 BLOG
N
News and Events Feed by Topic
MongoDB | Blog
MongoDB | Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Microsoft Security Blog
Microsoft Security Blog
Cisco Talos Blog
Cisco Talos Blog
P
Palo Alto Networks Blog
Schneier on Security
Schneier on Security

博客园 - Sameen

上下文工程学习笔记 什么是vibe ? 什么是 embedding ? vscode问题 document cookie JavaScript中的Date squash merge Element.scrollIntoView requestIdleCallback angular学习笔记 [转]React hooks useEffect中如何使用异步函数(即如何使用async/await) css斜条纹背景——linear-gradient 【转】过滤不可见字符 换电脑快捷同步vscode插件和配置 Git自动补全配置安装(Mac版本) Mac上看不到.git目录下的隐藏文件的解决方法 ts 问号点 ?. moment获取本月、上个月、近三个月时间段 iframe优缺点
angular中asObservable是什么的,为什么需要用?
Sameen · 2025-08-08 · via 博客园 - Sameen

Subject 本身既是观察者(Observer)又是可观察对象(Observable),这意味着它可以调用 next()error()complete() 等方法发送数据。但在实际开发中,我们通常希望 限制外部对 Subject 的直接操作,只允许外部订阅数据,而不能直接发送数据。

asObservable() 方法就解决了这个问题:

  • 它返回一个 只读的 Observable 视图,外部只能订阅这个 Observable 来接收数据
  • 外部无法调用 next() 等方法发送数据,保证了数据流的安全性和可控性
import { BehaviorSubject } from 'rxjs';

class DataService {
  // 内部使用 Subject 管理数据
  private dataSubject = new BehaviorSubject<string>('初始值');
  
  // 对外暴露只读的 Observable
  public data$ = this.dataSubject.asObservable();
  
  // 内部方法可以安全地发送数据
  updateData(newData: string) {
    this.dataSubject.next(newData);
  }
}

// 使用服务
const service = new DataService();

// 外部可以订阅数据
service.data$.subscribe(data => console.log('收到数据:', data));

// 外部无法直接调用 next(),以下代码会报错
// service.data$.next('非法修改'); // 错误:Property 'next' does not exist on type 'Observable<string>'

总结:

asObservable() 是一种封装技巧,通过隐藏 Subject 的写入能力(next() 等方法),只暴露读取能力(订阅),从而实现了数据流的单向性和可控性,这在 Angular 服务中共享数据时非常常用。