[Vue-rx] Switch to a Function which Creates Observables with Vue.js and Rxjs
Wrapping the creation of an Observable inside of a Function allows you delay the creation of the Observable until it is needed. This becomes really important when the Observable is created from a Promise due to the way Promises execute on creation.
Current Code:
<template> <section class="section"> <button class="button" v-stream:click="click$">Click</button> <h2> {{name$}} </h2> <img v-stream:error="imageError$" :src="image$" alt=""> </section> </template> <script> import { from, merge } from 'rxjs'; import { switchMap, pluck, map, mapTo } from 'rxjs/operators'; export default { name: 'app', domStreams: ['click$', 'imageError$'], subscriptions() { const person$ = from( this.$http.get( "https://starwars.egghead.training/people/1" ) ).pipe( pluck('data') ) const luke$ = this.click$.pipe( switchMap(() => person$) ) const name$ = luke$.pipe( pluck('name') ) const loadImage$ = luke$.pipe( pluck('image'), map(src => `https://starwars.egghead.trainin/${src}` ) ) const failImage$ = this.imageError$ .pipe( mapTo(`http://via.placeholder.com/400x400`) ) const image$ = merge( loadImage$, failImage$ ) return { name$, image$ } } }; </script>
The highlight part of code will be run once page loaded. So it means before the button was clicked, we already send a network request.
To defer the network request, we can do:
<template> <section class="section"> <button class="button" v-stream:click="click$">Click</button> <h2> {{name$}} </h2> <img v-stream:error="imageError$" :src="image$" alt=""> </section> </template> <script> import { from, merge } from 'rxjs'; import { switchMap, pluck, map, mapTo } from 'rxjs/operators'; export default { name: 'app', domStreams: ['click$', 'imageError$'], subscriptions() { const loadPerson = (url) => from( this.$http.get( url ) ).pipe( pluck('data') ) const luke$ = this.click$.pipe( mapTo("https://starwars.egghead.training/people/1"), switchMap((url) => loadPerson(url)) ); const name$ = luke$.pipe( pluck('name') ) const loadImage$ = luke$.pipe( pluck('image'), map(src => `https://starwars.egghead.training/${src}` ) ) const failImage$ = this.imageError$ .pipe( mapTo(`http://via.placeholder.com/400x400`) ) const image$ = merge( loadImage$, failImage$ ) return { name$, image$ } } }; </script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2016-07-18 [Angular 2] Building a Toggle Button Component