Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
OPOA那些事儿 ⼀一淘UX 李牧
[email protected]
2012-7-7
Slide 2
Slide 2 text
⼀一淘UX前端两个建设中的项目 For OPOA Since 2011 @GitHub For Components Since 2012 @GitHub
Slide 3
Slide 3 text
h;p://zuanshi.taobao.com (任意淘宝用户可访问) h;p://tanx.com 在复杂商业系统中的OPOA会多遇到哪些问题?
Slide 4
Slide 4 text
1.系统由非常多区块组成,如何管理这些区块? h;p://zuanshi.taobao.com/index.html#!/plan/ planmanage/
Slide 5
Slide 5 text
VOMTree记录Views逻辑层次关系 5
Slide 6
Slide 6 text
2.Hash变动如何通知到各个区块
Slide 7
Slide 7 text
MagixJS页面切换流程 当Hash发生改变,view会自外向内,响应和传递query 变化事件,这是一个捕获型事件,可以被打断. 7 Root View View2 View1 View2_1 View3 View2_2
Slide 8
Slide 8 text
3.大量区块深层次嵌套,配置是否特别繁琐?
Slide 9
Slide 9 text
树状关系里每个节点只 需要管理好自身和自身 的直接子节点 只需在配置项中记录每 个逻辑页面的RootView 9
Slide 10
Slide 10 text
4.同一区域位置不变内容更迭频繁
Slide 11
Slide 11 text
View的容器 -‐-‐ VFrame 11 我们需要有View的容器,在页面中划出⼀一个逻辑区块, View可以装载到容器中,也可以卸载掉. 这就像页面中的iframe,通过切换src改变iframe内容. 以整个页面的hash值作为每个mxvc的querystring
Slide 12
Slide 12 text
5.众多区块能否独立调试,多处重用?
Slide 13
Slide 13 text
VFrame和IFrame一样可以独立开发 13 以新增创意功能为例 独立使用此功能: h;p://zuanshi.taobao.com/index.html#!/board/boardhandle/ acXon=create 嵌入到计划创建流程中: h;p://zuanshi.taobao.com/index.html#!/plan/planhandle/ 完全独立开发调试: h;p://zuanshi.taobao.com/index.html#!/plan/planhandle/ __view__=app-‐views-‐board-‐boardhandle 我们只要强制指定RootView为VOMTree的某个View节点,就 可以只渲染这个节点为根的VOMTree的一颗子Tree
Slide 14
Slide 14 text
6.如何做到从任一URL进入系统,加载内容最 小化?
Slide 15
Slide 15 text
按需加载和预加载任务交给Loader 15 • h;p://zuanshi.taobao.com/index.html#!/board/boardhandle/ acXon=create • h;p://zuanshi.taobao.com/index.html#!/plan/planhandle/ • h;p://zuanshi.taobao.com/index.html#!/plan/planhandle/ __view__=app-‐views-‐board-‐boardhandle 每个View的相关JS,模板全部形成模块,有Loader根据URL按 需加载
Slide 16
Slide 16 text
7.如何控制单页应用内存使用?
Slide 17
Slide 17 text
拒绝Dom节点和JS对象循环引用 17 全局DataProxy对象 1 proxyObj1 2 proxyObj2 ... 3 proxyObj3 ... ... ...
key1 jsObj1 key2 jsObj2
参照jQuery.data的做法: $("#dv1").data(key1,jsObj1).data(key2,jsObj2); proxyindex="1" 通过为节点添加到expando字符串索引 指向全局DataProxy中的相应JS对象
Slide 18
Slide 18 text
参照jQuery.data的另类事件代理 18
北京
上海
myView.events = { click:{ showAreaCode : function(view,targetId,argsArr){...}, isLocal:function(view,targetId,argsArr){...} } } //内部保证listener接收到的参数view,targetId,argsArr为纯JS对象. 附加好处:节点上的事件⼀一目了然
Slide 19
Slide 19 text
8.页面改动频繁,组件如何自处?
Slide 20
Slide 20 text
h;p://zuanshi.taobao.com/index.html#!/reports/plan_realXme/ 将“注意XXYYZZ”信息加入到组件某个位置 一个最小的需求
Slide 21
Slide 21 text
引入模板引擎 如果组件完全有字符串拼接出来,“注意XXYYZZ”加 到哪里,哪里就要开一个配置项,积累下来组件配置 会一匹布那么长。 引入模板引擎,组件功能作用在模板上,可以在任意 位置加东西
Slide 22
Slide 22 text
9.模板类似HTML的静态文件,大系统一次性 写入不现实,如何即能方 便开发,又放在CDN上缓存?
Slide 23
Slide 23 text
预编译时解决问题 开发时: 通过XHR同域获取模板,格式缩进完美,Demo转化 为模板也非常容易。 上线时: 将模板转化为一个一行的长字符串,作为JS变量存储, 通过JSONP跨域获取
Slide 24
Slide 24 text
10.应用层框架能否独立与底层类库?
Slide 25
Slide 25 text
业务框架抽象类,部分方 法需要依赖底层类库实现 Loader适配器 业务框架实现类,会mix 到抽象类中形成完整类 打包编译工具 Kissy版本 SeaJS+ JQuery+ Backbone 版本 h;ps://github.com/limu/magix/tree/master/src
Slide 26
Slide 26 text
以上 以下 h$p://www.slideshare.net/leneli/magixjswebapp
Slide 27
Slide 27 text
11.当前我们的组件行为是作用在模板上的, 难道任何数据变化都需要全组件重新刷新?
Slide 28
Slide 28 text
12.只有NodeJS才能方便的将渲染从前台移动 到后台么?
Slide 29
Slide 29 text
13.组件系统如何做到面向未来可拆分?
Slide 30
Slide 30 text
等您来回答
Slide 31
Slide 31 text
关于我 李穆 花名: 李牧 邮箱:
[email protected]
博客: http://limu.iteye.com 微博: @lenel 进入阿里系⼀一直在广告线做前端 2007.01 雅虎 广告引擎团队 2007.05 阿里妈妈 广告引擎团队 2008.09 淘宝 广告技术部架构组 2011.06 ⼀一淘 UX北京团队 Velocity北京2010的分享:第三方广告代码稳定性和性能优化
Slide 32
Slide 32 text
Q&A
Slide 33
Slide 33 text
谢谢大家 Thank You