温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么理解Cycle js函数式和响应式的js框架

发布时间:2021-10-13 16:01:52 来源:亿速云 阅读:124 作者:柒染 栏目:开发技术

本篇文章为大家展示了怎么理解Cycle js函数式和响应式的js框架,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

  Cycle.js带有所有现代前端库的时髦基因:纯函数式,全响应式,组件化等等……它主要解决的核心问题是人机交互,最后我们还能发现这个其实更通用,我们可以用它构建更完整的响应式系统。

  Cycle.js的核心依赖

  是Rxjs,而Rxjs的核心是Observable。它现在是ES的stage-1提案,因此很可能在一两年内被加入原生js的Api。你现在可以把它简单看作一个高级Promise,而熟悉.Net的同学可以经常对比Linq思考。Promise是一个存储(可能存在)的值的异步容器,而Observable是存储流的容器,这些可爱的容器可以替我们打理异步序列、可能性、流这些抽象概念的上下文。

  分形架构的好处显而易见,就是复用容易,组合方便,Cycle.js推崇的也是分形架构。其将应用抽象为了一个纯函数main(sources),该函数接收一个sources参数,用来从外部环境获得诸如DOM、HTTP这样的副作用,再输出对应的sinks去影响外部环境。

  Cycle.js应用

  基于这种简单而直接的抽象,Cycle.js容易做到分形,即每个Cycle.js应用(每个main函数)可以组合为更大的Cycle.js应用:

  在分形体系下,通过runAPI,能驱动任何Cycle.js应用运行,无论它是一个简单的Cycle.js应用,还是一个嵌套复合的Cycle.js应用。

  import{div,label,input,hr,h2,makeDOMDriver}from'@cycle/dom'

  functionmain(sources){

  constinput$=sources.DOM.select('.field').events('input')

  constname$=input$.map(ev=>ev.target.value).startWith('')

  constvdom$=name$.map(name=>

  div([

  label('Name:'),

  input('.field',{attrs:{type:'text'}}),

  hr(),

  h2('Hello'+name),

  ])

  )

  return{DOM:vdom$}

  }

  run(main,{DOM:makeDOMDriver('#app-container')})

上述内容就是怎么理解Cycle js函数式和响应式的js框架,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI