Famous框架系列一:famous/core/Surface

famous/core/Surface

既然是Famous的第一篇文章,就先给Famous打个广告:http://periodic.famo.us  Famous12年的作品,点击右下角Fun things to do可以看到操作说明。

我认为Famous框架中最重要的部分莫过于Surface了。

Surface是所有能够被展现的元素的根本,它负责将可见的元素生成DOM输出(目前仅支持DOM,WEBGL版本正在他们的实验室里,并已有华丽视频放出,移步:https://famo.us/blog/)。心血来潮想写一点关于Famous的文章,又害怕自己坚持不下去,就挑重要的最先说吧。

Surface是个虚拟的DIV,真正的DIV是Surface._currentTarget--他的一个属性。Surface会创建一个DIV用以显示内容,并保持这个DIV的引用用于更新。

创建一个Surface:

var surface = new Surface({
    size: [100, 100],
    classes: [‘surface‘],
    content: ‘我是Surface!Hello Famous!‘,
    properties: {
        backgroundColor: ‘#fff‘
    },
    attributes: {
        name: ‘surfaceA‘
    }
}); 

说一下参数吧:这几个参数不加上也没关系,famous会按默认的来。

size:尺寸(尺寸很关键很关键,由于Famous是一个基于绝对定位的库,尺寸的设置对程序的影响巨大,将来会与Modifier一并说,如果写到这一篇的话。。)

classes:css类,是一个数组的形式

content:内容。这里的内容不仅仅是放几个字或者一两句话,而是一段HTML代码。就我个人的经验,大部分时候还是几个字。。在复制粘贴网络上类似10个酷炫的css效果的时候,插入HTML代码很有用(大牛轻喷,因为我会喷回去的:-D)。

properties:用于控制样式。所有Object.style下的属性都可以写在这里。好吧,就是控制css的地方。

attributes:控制属性的地方。

这些参数初始化的时候忘记写了也没关系,都有方法可以赋值的。比如setContent,setProperties等等,通通都有。

基础就是这些了,平时经常会用的也就是以上这部分。接下来进入意识流阶段,我想到啥就说啥了(意识模糊:-D)。

Surface默认生成的tag是DIV,但也可以生成别的,如<article>,<span>通通都可以。只要给初始化的实例设置这么一个属性:elementType。看源代码我们可以看到,Surface的elementType属性是‘div‘,所以如果我们需要修改tag名,只需要

surface.elementType = ‘span‘;

这样,之前代码创建的surface的tag就成了span。

Surface除了显示可见内容外还有一个重要的作用是接收和处理事件。Famous是一个挺高层的UI框架,作为框架的使用者,几乎完全不考虑操纵DOM,它唯一与DOM建立联系的就是Surface了,所以DOM的事件如鼠标点击,触摸等等都需要靠Surface来获得(Engine也会获取并处理一部分事件,仅限于body上的事件)。

Surface控制的dom(_currentTarget)在被部署(deploy)到页面时,会触发一个deploy事件。这个事件在你想要直接操作dom(_currentTarget)又纠结这个dom在不在的时候(Surface是虚拟DOM,不会在初始化的第一时间生成DOM部署进页面,而是在初始化后的第一个Engine Tick被部署),非常有用。

好吧,刚刚提到了Engine Tick,就简单解释一下吧:Famous跟游戏框架很像,差不多每秒刷新60次,游戏中一般称为帧,而Famous中我不知道这样称呼合不合适,就按英文的说法叫Engine Tick好了。

Surface有一个家族。目前的成员有(除了Surface):

CanvasSurface:用于生成<canvas>,干嘛的不用多说吧。恩,下面就随便全举出来好了。

ImageSurface:<img>

InputSurface:<input>

SubmitInputSurface:<input type="submit">

TextareaSurface:<textarea>

VideoSurface:<video>

ContainerSurface:这个既值得一说也不值得一说(好烦:-D),也是个<div>,所不同的是,可以向其中加入其它需要显示的元素,比如往里面加一个Surface和两个ImageSurface,看名字就知道起到一个容器的作用。这个容器本身是个<div>可以直接写内容的。

FormContainerSurface:上面容器的<form>版

每个Surface初始化的时候都可以方便地码出这个Surface的全部css参数,虽然Famous也是支持给Surface配置css类的,但很多时候,一两个属性直接写比较方便。特别是移动端的情况下,少用css,样式参数全写进代码里,能减少服务器请求。把参数写进代码还有一个好处就是方便程序动态调整,比如适配屏幕的时候,fontSize可以根据屏幕的尺寸做像素级的调整。

Surface默认是自带一个css类的:famous-surface。

这个css类首当其冲的就是position: absolute。整个Famous框架都是建立在绝对定位的基础上,个人感觉Famous很多地方更像一个游戏框架。通过绝对定位,有效的降低了dom树的复杂度,并建立自己的渲染树,藉此提升性能,华丽的动画从这里开始。(物理引擎,缓动函数)

构造函数中各种改动标识符,_sizeDirty,_contentDirty,对Surface进行更新的时候,尽量使用提供的各种set方法。。也算是常识吧。。没啥好说的。每一个Tick,都会检查当前的size,content之类的是否dirty,有就更新。

Surface.prototype.setup = function setup(allocator) {
        var target = allocator.allocate(this.elementType);

Famous自带一个DOM对象池,每次生成新的对象都会从池子里找找有没有能用的不在树里的DOM节点。

对应的,这个surface不用了,会被回收。

this.detach(target);
this._currentTarget = null;
allocator.deallocate(target);

内置一个EventHandler。

this._eventOutput = new EventHandler();
this._eventOutput.bindThis(this);

可以监听浏览器事件(on),抛出自定义事件(emit),还可以向其他的事件接收者推送自身的事件(pipe)。

surface.on(‘click‘, function(event){   //监听浏览器的点击事件
    console.log(event);
    surface.emit(‘onClick‘);                //抛出一个onClick事件
});

好啦,关于Surface没啥能说的了。

时间: 2024-08-27 14:57:53

Famous框架系列一:famous/core/Surface的相关文章

SpringMVC 框架系列之初识与入门实例

SpringMVC 框架系列之初识与入门实例 1.SpringMVC 概述 (1).什么是 MVC:Model-View-Control Control 层属于框架性质,完成的主要工作是:封装 web 请求为一个数据对象.调用业务逻辑层来处理数据对象.返回处理数据结果及相应的视图给客户端. (2).什么是 SpringMVC Spring mvc 和 Struts2 都属于表现层的框架,是 Spring 框架的一部分,Spring 框架的 Control 层的核心是 DispatcherServ

2019 年起如何开始学习 ABP 框架系列文章-开篇有益

2019 年起如何开始学习 ABP 框架系列文章-开篇有益 [[TOC]] 本系列文章推荐阅读地址为:52ABP 开发文档 https://www.52abp.com/Wiki/52abp/latest/Welcome-to-52abp 本文的目的是为了让刚刚接触 ABP 框架的同学或者准备接触 ABP 框架的同学,能够理解和搞明白 ABP 框架到底是怎么回事,毕竟它发展了好几年的时间.社区中有很多人做 了 ABP 的资料和文章包括我自己也建立了 52ABP,社区中还有 ABPplus 等等的内

Quartz.NET开源作业调度框架系列

Quartz.NET是一个被广泛使用的开源作业调度框架 , 由于是用C#语言创建,可方便的用于winform和asp.net应用程序中.Quartz.NET提供了巨大的灵活性但又兼具简单性.开发人员可用它快捷的创建并执行一个自动化作业.Quartz.NET有很多特征,如:数据库支持,集群,插件,支持cron-like表达式等. 针对Quartz.NET的使用,从基础入门,Cron表达式,不同job间进行参数传递进行了介绍,并对插件任务进行了描述,最后将AdoJobStore如何保持到数据库中进行

从零开始搭建android框架系列(转)

网址:从零开始搭建android框架系列 githup:https://github.com/CameloeAnthony/Ant

基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(4) - EF Core CodeFirst 数据库创建

概述 在 基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(2) - EF Core (MySQL) CodeFirst 数据库迁移与依赖注入 一文中,我们介绍如何快速以CodeFirst快速搭建数据库,这一章,我们来完善一下创建数据库中可以添加的验证与约束. 微软爸爸官方文档:Entity Framework Core 数据库操作 (1) 数据库迁移  add-migration [任一名称,须唯一] (2) 更新数据库  update-database (3) 删除数据库迁

ASP.NET Core 配置 EF 框架服务 - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 配置 EF 框架服务 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 EF 框架服务 上一章节中我们了解了 Entity Framework 的基本工作原理和 DbContext ,我们也创建了一个自己的 HelloWorldDBContext. 本章节我们就来讲讲如何设置我们的 EF 框架来链接到 SQLite 数据库 配置 EF 框架服务 要让我们的 EF 框架的 DBContext 能够运行起来,我们需要更改一

【光速使用开源框架系列】数据库框架OrmLite

[关于本系列] 最近看了不少开源框架,网上的资料也非常多,但是我认为了解一个框架最好的方法就是实际使用.本系列博文就是带领大家快速的上手一些常用的开源框架,体会到其作用. 由于作者水平有限,本系列只会描述如何快速的使用框架的基本功能,更多的详细设置大家可以在这些项目的页面上找到. [介绍]: ORMLite是一款辅助开发数据库的框架,可以通过给实体配置标注来快速建立数据表,也可以通过其提供的DAO类中的方法来快速对数据库进行操作,如增删改查等. [项目页面]: http://ormlite.co

【APS.NET 框架系列】浅谈ASP.NET 框架

   本篇文章稍微偏原理且底层,有一定难度和且比较晦涩. 本篇文章主要是从广度上概括一下,具体的更细粒度的,会在后续的文章中,结合具体的Demo实例分析. 一 .NET框架概述 1.作用:提供了基于.NET框架开发的基础平台和模板,为.NET开发的基架; 2.基本构成:可支持语言,CLS,模板框架,基本模板,基本操作,基本类库,公共需要运行时,CTS和CLS,OS等; (1)可支持语言:.NET框架可支持vb,c++,c#,F#,js等语言开发; (2)CLS:通用语言规范,使多种语言开发成为了

【光速使用开源框架系列】图片加载框架ImageLoader

[关于本系列] 最近看了不少开源框架,网上的资料也非常多,但是我认为了解一个框架最好的方法就是实际使用.本系列博文就是带领大家快速的上手一些常用的开源框架,体会到其作用. 由于作者水平有限,本系列只会描述如何快速的使用框架的基本功能,更多的详细设置大家可以在这些项目的页面上找到. [介绍]: ImageLoader作为一款开源的异步图片加载框架,在Android开发中经常被使用到,该控件可以加载和显示图片.并且对其进行缓存,提供了很多方便的选项帮助开发者们快速达到开发需求. [GitHub页面]