[关闭]
@mircode 2016-07-12T11:31:08.000000Z 字数 3861 阅读 967

Her前端高性能渲染解决方案

her


一、Her是什么

Her一方面集成了FIS的前端工程化能力,能够有效的解决前端开发中自动化工具、性能优化、模块化框架、开发规范、代码部署、开发流程等问题。同时又在此基础上实现了Pagelet和类Bigpipe输出渲染控制,从而有效的提升了页面加载和渲染性能,所以说Her是一个页面高性能的渲染方案。

二、为什么说Her是高性能

Her

这种架构图中,我们可以看到Her相当于FIS来说,增加了对页面渲染做了优化。对于首屏幕界面,Her实现了

三、使用Her

1、安装Her工具

  1. npm install her -g # or sudo npm install her -g

2、项目目录规范

  1. home # 模块名
  2. |- lib (前后端运行时代码目录,即 her-runtime)
  3. |- page (页面模板目录)
  4. |- static (静态资源目录)
  5. |- widget (模块化资源目录)
  6. |- fis-conf.js (构建工具配置文件)

3、发布项目

  1. her release -cw

4、启动服务器

  1. her server init # 下载 smarty rewrite 模块等
  2. her server start --type php

四、Smarty模板

1、基本标签

Her中,分别使用{html},{head},{title},{body}来替换HTML中的,html,head,title,body标签。

2、pagelet标签

Her中,通过是用pagelet标签,对页面进行细粒度的分块。分块收集HTML 片段及其依赖的CSS、JS资源,对页面模块进行细粒度编码,分解资源依赖和数据获取等。

2.1 执行流程

页面会首先把{Pagelet}区块输出成一个空的div占位,同时会输出code标签,内容就是对应Pagelet的html片段,接下来再通过Bigpipe.onPageletArrive的方式输出这个Pagelet。

  1. <html>
  2. <head><link href="{框架样式}" /></head>
  3. <body>
  4. {pagelet}
  5. HTML内容
  6. <script runat="server">
  7. //区块的功能
  8. </script>
  9. {/pagelet}
  10. {pagelet}HTML内容{/pagelet}
  11. {pagelet}HTML内容{/pagelet}
  12. </body>
  13. </html>

运行时代码会成为

  1. <html>
  2. <head><link href="{框架样式}" /></head>
  3. <body>
  4. <div id="__elm_0_1"></div>
  5. <div id="__elm_0_2"></div>
  6. <div id="__elm_0_3"></div>
  7. <script src="{框架Js}"></script>
  8. <code id="__cnt_0_1" style="display:none"><!-- HTML片段 --></code>
  9. <script>
  10. Bigpipe.onPageletArrive({
  11. "id":"__elm_0_1",//Pagelet ID
  12. "container_id":"__cnt_0_1",//片段内容ID
  13. "css":[],//依赖样式
  14. "js":[],//依赖脚本
  15. "callback":{"load":["__cb_0_1"]}//回调函数名
  16. });
  17. </script>
  18. </body>
  19. </html>

2.2 渲染方式

支持四种渲染方式server|lazy|none|default

通过渲染方式的设置,我们可以方便实现核心(首屏)模块优先输出、非核心模块延迟输出,模块开关等。

3、script标签

{script}标签用来标注并收集页面中的代码片段。在输出时,Her 会将收集的代码封装成函数并且自动控制调用时机。
{script} 标签支持 pagelet-on 属性,用来控制脚本执行的时机。默认为 "load" ,即 pagelet 的HTML加载后执行。

同时该标签,还支持传入参数

  1. {$name="我是含有引号( ' )的用户名"}
  2. <script runat="server" pagelet-on="beforeload" var-userName=$name>
  3. var xxx = require(xxx);
  4. xxx.XXX();
  5. alert(userName);
  6. </script>

运行时代码会成为

  1. <script>
  2. BigPipe.hooks["系统管理的ID"] = function(require, pagelet){
  3. var userName = "我是含有引号( \' )的用户名";
  4. var xxx = require(xxx);
  5. xxx.XXX();
  6. alert(userName);
  7. };
  8. </script>

4、require标签

{require} 标签用来标注一个资源依赖。可以用于CSS和Js资源, resourcePath 为资源路径。

  1. {require name="common:js/jquery.js"}
  2. {require name="common:css/color.css"}

5、define标签

{define} 标签用来定义一个可重用模板片段,该片段可以通过 {widget} 标签调用。

  1. {*common:widget/title/title.tpl*}
  2. {define userName="默认用户名"}
  3. <!-- 一个可以重用的用户名显示组件 -->
  4. <dl>
  5. <dt>姓名</dt>
  6. <dd>{$userName|escape}</dd>
  7. </dl>
  8. {/define}
  1. {*调用方式如下:*}
  2. {widget name="common:widget/title/title.tpl" userName="张三"}

6、widget标签

{widget} 标签用来调用用 {define} 定义的可重用的模板片段。

五、JS编程接口

1、BigPipe接口

BigPipe.fetch(pagelets[, url, cache]) 函数
用于局部刷新页面,pagelets为需要刷新的区块的id数组,url为请求区块的url地址。

  1. BigPipe.fetch(["sidebar","container"], "index?nav=1", true);

2、Require接口,支持AMD规范

三个接口方法

requier方法,用于加载依赖的,被 require的模块将在引用代码执行前被加载。(AMD规范,同步加载)

defer和async方法,用于动态加载模块。支持加载JS和CSS,加载完毕后执行callback方法回调。(CMD规范,异步加载)

注意
require.defer 与 require.async 唯一的区别在于: require.defer 会将模块的加载推迟到页面 onload 之后,以防止对首屏速度的影响。一般来说不建议使用,请用 require.defer 替代。

六、CSS编程接口

1、CSS依赖

通过注释中的 @require moduleName moduleName 来标明这个文件的依赖css文件名,支持绝对和相对路径。

例如:

  1. /**
  2. * slogan也使用了 section的样式
  3. * @require ../section/section.css
  4. */

2、URL图片定位

Her同时支持CSS背景图片定位的能力,对于开发者,只需要根据开发目录写图片的相对路径即可。

  1. #forkme_banner {
  2. background: url('blacktocat.png') #0090ff no-repeat 95% 50%;
  3. filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='macbook.png')
  4. }

编译后

  1. #forkme_banner {
  2. background: url('/static/home/widget/slogan/blacktocat.png') #0090ff no-repeat 95% 50%;
  3. filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='/static/home/widget/slogan/macbook.png')
  4. }
  5. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注