[Cycle.js] Hyperscript as our alternative to template languages
Usually we use template languages like Handlebars, JSX, and Jade to create. One simple way we can create our own template language is to write a function that returns these objects for us. This lessons shows how we can use these functions as a DSL to create our DOM description objects.
Code to be refactored:
function main(sources) {
  const mouseover$ = sources.DOM.selectEvents('span', 'mouseover');
  const sinks = {
    DOM: mouseover$
      .startWith(null)
      .flatMapLatest(() =>
        Rx.Observable.timer(0, 1000)
         .map(i => {
           return {
             tagName: 'H1',
             children: [
               {
                 tagName: 'SPAN',
                 children: [
                   `Seconds elapsed: ${i}`
                 ]
               }
             ]
           };
         })
      ),
    Log: Rx.Observable.timer(0, 2000).map(i => 2*i),
  };
  return sinks;
}
Inside map, return a large object which represent html element.
We can create a function which accept 'tagName'and 'children', to simply our main function:
function h(tagName, children) {
  return {
    tagName: tagName,
    children: children
  }
}
// Logic (functional)
function main(sources) {
  const mouseover$ = sources.DOM.selectEvents('span', 'mouseover');
  const sinks = {
    DOM: mouseover$
      .startWith(null)
      .flatMapLatest(() =>
        Rx.Observable.timer(0, 1000)
         .map(i =>  h('H1', [
               h('SPAN', [
                   `Seconds elapsed: ${i}`
                 ])
             ])
         )
      ),
    Log: Rx.Observable.timer(0, 2000).map(i => 2*i),
  };
  return sinks;
}
Also we can create function for each tagName to even simply our code:
function h(tagName, children) {
  return {
    tagName: tagName,
    children: children
  }
}
function h1(children){
  return {
    tagName: 'H1',
    children: children
  }
}
function span(children){
   return {
    tagName: 'SPAN',
    children: children
  }
}
// Logic (functional)
function main(sources) {
  const mouseover$ = sources.DOM.selectEvents('span', 'mouseover');
  const sinks = {
    DOM: mouseover$
      .startWith(null)
      .flatMapLatest(() =>
        Rx.Observable.timer(0, 1000)
         .map(i =>  h1([
              span([
                   `Seconds elapsed: ${i}`
                 ])
             ])
         )
      ),
    Log: Rx.Observable.timer(0, 2000).map(i => 2*i),
  };
  return sinks;
}
The reason why we're introducing this function in the first place is that it looks really similar to what exists in cycle-dom, and it's a function called hyperscript. That's where the H comes from. That's our alternative to a template language.
This is a precursor to what we're going to see in cycle-dom. We're going to replace this outermost object, as well, with return H of H1 as a tag name, and the children are this array with the span. Then we can also simplify this error function like that.
[Cycle.js] Hyperscript as our alternative to template languages的更多相关文章
- 学习RxJS:Cycle.js
		原文地址:http://www.moye.me/2016/06/16/learning_rxjs_part_two_cycle-js/ 是什么 Cycle.js 是一个极简的JavaScript框架( ... 
- jquery.cycle.js简单用法实例
		样式: a{text-decoration: none;} *{;;} /*容器设置*/ .player { width:216px; height:248px; background:url(htt ... 
- [Cycle.js] The Cycle.js principle: separating logic from effects
		The guiding principle in Cycle.js is we want to separate logic from effects. This first part here wa ... 
- [Cycle.js] Hello World in Cycle.js
		Now you should have a good idea what Cycle.run does, and what the DOM Driver is. In this lesson, we ... 
- [Cycle.js] From toy DOM Driver to real DOM Driver
		This lessons shows how we are able to easily swap our toy DOM Driver with the actual Cycle.js DOM Dr ... 
- jquery.cycle.js
		jquery.cycle.js简单用法实例 样式: a{text-decoration: none;} *{margin:0; padding:0;} /*容器设置*/ .player { width ... 
- jquery图片切换插件jquery.cycle.js参数详解
		转自:国人的力量 blog.163.com/xz551@126/blog/static/821257972012101541835491/ 自从使用了jquery.cycle.js,我觉得再也不用自己 ... 
- RxJS/Cycle.js 与 React/Vue 相比更适用于什么样的应用场景?
		RxJS/Cycle.js 与 React/Vue 相比更适用于什么样的应用场景? RxJS/Cycle.js 与 React/Vue 相比更适用于什么样的应用场景? - 知乎 https://www ... 
- jQuery图片切换插件jquery.cycle.js
		Cycle是一个很棒的jQuery图片切换插件,提供了非常好的功能来帮助大家更简单的使用插件的幻灯功能 下载cycle插件并引入,此时,注意把引入它的代码放在引入jQuery主文件之后. <he ... 
随机推荐
- io系统
			一.浅谈io系统 io系统的结构化思想是:输入-转换流-装饰器-输出. 对于字节流来说,常见的结构类为: package com.handchina.yunmart.middleware.servic ... 
- mysql常用操作(转自阿铭linux)
			在前面两个章节中已经介绍过MySQL的安装了,但是光会安装还不够,您还需要会一些基本的相关操作.当然了,关于MySQL的内容也是非常多的,只不过对于linux系统管理员来讲,一些基本的操作已经可以应付 ... 
- DEV SIT UAT
			DEV环境:DEV顾名思义就是develop,即代码开发的环境.SIT环境:System Integration Test系统集成测试,开发人员自己测试流程是否走通.UAT环境:User Accept ... 
- FileZilla 安装配置参考
			http://www.admin10000.com/document/72.html 解决 NAT issue https://wiki.filezilla-project.org/Network_C ... 
- 页面全屏显示JS代码
			1.直接在页面加载时就全屏. <body onload="window.open(document.location,'big','fullscreen=yes'):window.cl ... 
- 用pod导入ReactiveCocoa
			用pod导入ReactiveCocoa [1] 第一种 platform:ios,'7.0' pod 'ReactiveCocoa' [2] 第二种 pod 'ReactiveCocoa','2 ... 
- web 安全 初探 (正在更新)
			1.web应用程序所采用的防卫机制的几个核心构成:1.处理用户对应用程序的数据和功能的访问,以防止用户未经授权访问.2.处理用户的输入,以防止恶意的输入导致未预期的行为.3.处理攻击,以确保应用程序在 ... 
- Codeforces Round #350 (Div. 2)A,B,C,D1
			A. Holidays time limit per test 1 second memory limit per test 256 megabytes input standard input ou ... 
- C++的学习记录 - 0
			最近玩Arduino发现,在编写函数库的时候要用到C++.正好手头有一本教材,于是时隔2年,开始重学. 又看到重载.构造.拷贝这些词竟然还有些小兴奋. 开个系列日志记录一下学习过程中的问题和体会. 看 ... 
- [Mugeda HTML5技术教程之18]如何在Android应用中使用Mugeda动画内容
			1.简介 本文主要介绍如何在Android应用程序中使用Mugeda动画.Mgeda动画是标准HTML5格式的动画,在Android应用程序中可以使用WebView来加载Mugeda动画.动画内容本身 ... 
