介绍

Elf.js 是一个简洁的高效的JavaScript框架。它不仅高度重视用户的体验,也高度重视开发者的体验。在实现当今主流技术的同时,以尽可能原生态的形式展现出来。在如今花样繁多的框架中,你是否感觉各种思想、语法、工具大大增加了你的学习时间,那么Elf.js是一个不错的开始。她将最初的 Web 设计理念与现代技术完美结合,她追求的是简单、明朗、返璞归真。

安装


  • NPM
    npm install elfjs --save
  • 文件

    • NPM包的目录你将找到.js(完整版).min.js(迷你版)以及.d.ts(类型声明)文件。
    • elf-loader.js提供简单的AMD/CommonJS规范的加载器,她可以让你在开发中免去编译的等待。
    • shims目录下的提供在IE9上运行的补丁与集成第三方库的补丁。她们并不是时常用到。
    • 使用支持 DefinitelyTypedIDE 可以有效的进行代码提示与类型检查。

开始

Elf.js并未创建过多的私有思想和语法。若你已经具有 Web 中级知识,那么一切将非常得心应手。

第一个组件


  • Elf.js采用简洁的模板语法来声明 DOM 与数据。
    <!-- viewComponent.html -->
<div>
{{ message }}
</div>
    // viewComponent.js
var temp = require("viewComponent.html");
module.exports = Elf.Component("view", {
constructor : function () {
this.message = "Hello Word!";
},
render : Elf.redactElement(temp)
});
    // bootstrap.js
var View = require("viewComponent");
Elf.render(Elf.createElement(View), document.body, true);
  • 上面的代码展示了如何从模板中创建组件和如何将组件渲染到指定节点。
  • 更多模板语法参见 模板语法

使用指令


  • Elf.js提供可增强HTML特性的功能。下面将展示一个简单的拖动功能。
    // dragDirective.js
module.exports = Elf.Directive("drag", {
onInitial : function (element, props) {
Elf.attachEvent(element, "mousedown", this);
Elf.attachEvent(element, "mousemove", this);
Elf.attachEvent(element, "mouseup", this);
},
onDispose : function (element, props) {
Elf.detachEvent(element, "mousedown", this);
Elf.detachEvent(element, "mousemove", this);
Elf.detachEvent(element, "mouseup", this);
},
handleEvent : function (event) {
// coding drag
}
});
    <!-- viewComponent.html -->
<div cmd="drag">
{{ message }}
</div>
    // viewComponent.js
var temp = require("viewComponent.html");
var dragDirective = require("dragDirective");
module.exports = Elf.Component("view", {
constructor : function () {
this.message = "Hello Word!";
},
render : Elf.redactElement(temp, dragDirective)
});
  • 通过Elf.Directive方法,我们定义并实现了一个拖动指令。通过Elf.redactElement函数注入依赖的指令(已经通过Elf.depend方法注册为全局依赖则不必在这里注入了),就可以在模板中通过指令别名使用了。此时的div已经具备拖动能力。
  • 指令能有效的将功能操作与业务逻辑分离,并高度重用代码。

使用管道


  • 在渲染过程中,往往数据需要转换成某种特定格式,我们可以通过Transform来实现。例如下面代码将日期格式化输出。
    // dateTransform.js
module.exports = Elf.Transform("date", {
transform : function (value, formatExpr) {
return moment(value).format(formatExpr);
}
});
    <!-- viewComponent.html -->
<div cmd="drag">
{{ now | date "YYYY-MM-DD" }}
</div>
    // viewComponent.js
var temp = require("viewComponent.html");
var dateTransform = require("dateTransform");
module.exports = Elf.Component("view", {
constructor : function () {
this.now = new Date();
},
render : Elf.redactElement(temp, dateTransform)
});
  • 上面的代码最终将日期输出为xxxx-xx-xx格式。
  • 管道与指令一样,都是为了将功能操作与业务逻辑分离,使得相同的功能能得以重用。

事件处理


  • Elf.js的事件绑定与原生HTML一样。
    <!-- viewComponent.html -->
<button onclick="onClick($event);">
点击试试
</button>
    // viewComponent.js
var temp = require("viewComponent.html");
module.exports = Elf.Component("view", {
render : Elf.redactElement(temp),
onClick : function (event) {
alert("点击被触发了!");
}
});
  • Elf.js将会自动管理事件的绑定与移除,即使在循环中也不必担心作用域的问题。也不必担心性能问题。
  • Elf.js提供了一套与原生一样的冒泡机制,Component亦可作为触发事件的对象。

组件通讯


  • 因为Elf.js实现的事件机制与原生相同,并且可作用与Component,所以Elf.js不需要额外的状态管理手段。子组件的事件通过这种机制会冒泡到Individual,你只需在Individual处处理业务逻辑即可。又因为Elf.js是自动响应的,你也不需要关心数据变化后的呈现。她会自动分析新的数据与之前的数据,将更新呈现在页面上。
  • Elf.js并不提供双向绑定,亦不推崇单向数据流。原始的事件机制就是最好的手段,她早已深入每一个前端程序员心中。
  • 这里我们使用一个完整的示例 elfjs-calendar
  • sldier.jscalendar.js里分别抛出了日历操作事件,在main.js业务逻辑。

进阶

正如上面的教程,Elf.js核心只提供了ComponentDirectiveTransform三个对象。模板中只提供了两个控制流程的属性(e-fore-if)和一个文本输出{{ }}。但Elf.js在背后所做的远远不止于此。她有着高效的虚拟DOM和原生一样的事件机制,还能自动响应数据变化。如果你想深入了解其原理(其实现在主流框架的原理都是相近的)。Elf.js为一个极简的框架,将会是一个最好最优的选择。

深入响应式原理


zone.js 启发。数据的改变的时机无外乎用户操作(触发事件)和异步函数(AjaxsetTimeout等)。Elf.js封装了事件监听和常用的异步操作。使之能够得到监控,在这些异步操作结束后,Elf.js将会去计算数据变化,然后以最优的方式更新DOM

集成第三方类库


由于Elf.js封装了原生的事件,但并没有像 zone.js 一样侵入。所以通过Elf.js创建的DOM不再触发用原生方法绑定的事件。因此第三方类库的监听可能无法触发其绑定的事件。通过引入shims_for_Lib.js可以让Elf.js接管WindowNode的事件监听。从而让第三方类库完美运行,亦可自动响应数据变化。

使用扩展语言


Elf.js无缝支持JSXelf.d.ts中可以找到JSX定义)。但Elf.js更推荐使用模板。相较于JSX,模板有着良好的结构,视图与逻辑分离,更好的与UI合作。同时,使用elf-loader.js加载模板,会有source map,弥补了模板调试难的短板。

生产环境部署


如同之前的开发一样,我们使用node开发,AMDCommonJS的风格都能支持,在开发阶段无需编译、打包,并有source map输出,拥有非常好的开发体验。在使用打包工具(如:webpack)打包后不再输出source map,在没有察觉的情况下就已经提升了性能。打包过程中亦无需其它loader。当然,若想追求极致性能可以使用loader将模板预编译为 JavaScript 。

ElfJS从入门到精通(一)的更多相关文章

  1. <程序员从入门到精通> -- How

    定位 自己才是职业生涯的管理者,想清楚自己的发展路径: 远期的理想是什么?近期的规划是什么?今日的任务和功课又是什么? 今日之任务或功课哪些有助于近期之规划的实现,而近期之规划是否有利于远期之理想? ...

  2. 【无私分享:从入门到精通ASP.NET MVC】从0开始,一起搭框架、做项目 目录索引

    索引 [无私分享:从入门到精通ASP.NET MVC]从0开始,一起搭框架.做项目(1)搭建MVC环境 注册区域 [无私分享:从入门到精通ASP.NET MVC]从0开始,一起搭框架.做项目(2)创建 ...

  3. ASP.NET MVC4入门到精通系列目录汇总

    序言 最近公司在招.NET程序员,我发现好多来公司面试的.NET程序员居然都没有 ASP.NET MVC项目经验,其中包括一些工作4.5年了,甚至8年10年的,许多人给我的感觉是:工作了4.5年,We ...

  4. Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引

    因为内容比较多,所以每篇讲解一些内容,最后会放出全部代码,可以参考.操作中总会遇到各式各样的问题,个人对部分问题的研究在最后一篇 问题研究 里.欢迎大家探讨学习. 代码都经过个人测试,但仍可能有各种未 ...

  5. 1、ASP.NET MVC入门到精通——新语法

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 在学习ASP.NET MVC之前,有必要先了解一下C#3.0所带来的新的语法特性,这一点尤为重要,因为在MVC项目中我们利用C#3.0的新特 ...

  6. 5、ASP.NET MVC入门到精通——NHibernate代码映射

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 上一篇NHibernate学习笔记—使用 NHibernate构建一个ASP.NET MVC应用程序 使用的是xml进行orm映射,那么这一 ...

  7. 6、ASP.NET MVC入门到精通——ASP.Net的两种开发方式

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 目前,ASP.NET中两种主流的开发方式是:ASP.NET Webform和ASP.NET MVC.从下图可以看到ASP.NET WebFo ...

  8. 7、ASP.NET MVC入门到精通——第一个ASP.NET MVC程序

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 开发流程 新建Controller 创建Action 根据Action创建View 在Action获取数据并生产ActionResult传递 ...

  9. 8、ASP.NET MVC入门到精通——View(视图)

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 View视图职责是向用户提供界面.负责根据提供的模型数据,生成准备提供给用户的格式界面. 支持多种视图引擎(Razor和ASPX视图引擎是官 ...

随机推荐

  1. Android 常见 Memory Leak 原因及解决办法总结

    待整理: http://geek.csdn.net/news/detail/50692 背景 在Android开发过程中,我们经常碰到的情况就是在我们不清楚为什么情况下,程序突然出现Crash了.其中 ...

  2. NOIP2014无线网络发射器选址改编1

    问题描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129条东西向街道和129条南北向街道所形成的网格状,并且相邻的平 ...

  3. Cs Round#54 D Spanning Trees

    题意:构造一张N个结点无重边.无自环的无向图.使得其最小生成树和最大生成树共享K条边. 样例一很具有启发性: 当K!=0时,我们可以先构造出一条链,链的长度为n-k的链,作为最小生成树的一部分,之后由 ...

  4. 大数据学习系列之五 ----- Hive整合HBase图文详解

    引言 在上一篇 大数据学习系列之四 ----- Hadoop+Hive环境搭建图文详解(单机) 和之前的大数据学习系列之二 ----- HBase环境搭建(单机) 中成功搭建了Hive和HBase的环 ...

  5. MySQL系列:高可用架构之MHA

    前言 从11年毕业到现在,工作也好些年头,入坑mysql也有近四年的时间,也捣鼓过像mongodb.redis.cassandra.neo4j等Nosql数据库.其实一直想写博客分享下工作上的零零碎碎 ...

  6. 设计模式(8) - 迭代器模式(iterator)- 实现ArrayList和linkedList的迭代器

    上周六就開始写这篇博客,之后一直耽误了.到前天才開始写.今天醒的早,就把这部分整理一下. 本文内容參考易学设计模式和马士兵的迭代器模式的视频. 了解迭代器模式一个作用就是让你在使用 迭代器遍历集合类的 ...

  7. JDBC中的Statement和PreparedStatement的差别

    以Oracle为例吧 Statement为一条Sql语句生成运行计划, 假设要运行两条sql语句 select colume from table where colume=1; select col ...

  8. SpringMVC上传图片并压缩及剪切demo

    /** * */ package com.up.controller; import java.awt.Image; import java.awt.image.BufferedImage; impo ...

  9. SharePoint Framework 简介

    作者:陈希章 发表于 2017年12月25日 前言 通过前面几篇文章,我相信大家对于SharePoint Online的开发有了更加全面的认识,上一篇 介绍的SharePoint Add-in的开发, ...

  10. python 列表解析

    列表解析,主要用于动态创建列表 本篇主要说一下,lambda.map().和filter()同列表解析语句之间结合的用法 列表解析的基本语法为:[expr for iter_var in iterab ...