现在的位置: 首页 > web前端 > 正文

Cycle js_函数式和响应式的 js 框架

2020年07月09日 web前端 ⁄ 共 1032字 ⁄ 字号 评论关闭

  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,h1,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(),


  h1('Hello'+name),


  ])


  )


  return{DOM:vdom$}


  }


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


  复制代码


  总之,Cycle.js应用给大家简单的介绍了一些,希望大家多看看。

抱歉!评论已关闭.