avalon源码阅读(1)
写angularJS源码阅读系列的时候,写的太垃圾了。
一个月后看,真心不忍直视,以后有机会的话得重写。
这次写avalonJS,希望能在代码架构层面多些一点,少上源码、多写思路。
avalon暴露句柄方式 、、已经不是这样了
(function(DOC){
...
avalon=...//没有var
...
})(document)
具体暴露句柄方式的讲解,在这里。
avalon Dom遍历
源码的末尾执行了这么avalon.ready(function(){...})一个函数,
而这个函数的末尾为avalon.scan(DOC.body)
于是乎,avalon开始了读body旅程。
在这旅程中,
有scanNodes、scanTag、scanAttr、scanText、scanExpr、scanTemplate需要来回流转运用。
在讲解读取dom之前,我们先了解下dom的组成,节点类型(document.nodeType):
节点类型(nodeType) 元素类型
元素element
属性attr
文本text
注释comments
文档document
我们可以通过节点类型和
具体的元素标签
来判定将要解析的 和 不会去解析的。
scanNodes
我们先看scanNodes(parentElement,vmodels)函数,
他的作用是通过parentElement.firstChild``child.nextSibling 遍历当前dom下 的子节点,
并且通过节点类型的判定,各自调用scanTag(nodeType==1)
和scanText(NodeType==8 && 存在{{...}})函数。
scanTag
scanTag(elem, vmodels, node),这个函数蛮有意思的,
第三个参数node是作者不想进行var声明,直接写在参数里的。
这个函数的作用是判定avalon执行作用域的,
作用域有三类:ms-skip ms-import和 ms-controller(有优先顺序),
ms-important不包含父VM,ms-controller相反会有继承效果。
当然,这时候游览器还没有执行用户自定义的avalon.defined,
所以不会调用scanAttr继续旅行的。 、、待定
scanText
scanText(textNode, text, vmodels),顾名思义,
会具体解析解析...{{...}}...的值。这样的话,
就会涉及avalon filter的解析,具体解析方法放在scanExpr里面,
scanText主要替换...{{...}}...为解析后的数据,
并且如果有用了filter的话,会调用executeBindings进行相应的处理。
该函数会产生一个记录scanText解析结果的object。数据结构为:
{
type: "text",//类型
node: node,//替换后的element
nodeType: 3,//节点类型
value: token.value,
filters: token.filters
//token 为scanExpr的返回值
}
scanExpr
scanExpr(str),这个函数只要知道返回的结果格式就好。
scanAttr
scanAttr(elem, vmodels)这个函数super重要的,
他会针对 avalon封装的事件 和 ms-if repeat widget 等做相应的处理。
会在下一章连同 executeBindings 一块讲解。
scanTemplate
scanTemplate属于模板加载,
以后可能会在这里补上或者新开一篇文章单独讲解它。
小记
如果 有遍历dom需求的话 ,上面代码可经过 去除依赖处理后 摘出来。
基本流程:从头到脚的开始遍历,
根据存放在 dom attribute的值 来判定业务需求和 v m作用域,
ms-duplex属性和 {{}} 做占位符,等待渲染和占位符替换。
VMODELS object则存 放着要 渲染进页面的数据。
avalon源码阅读(1)的更多相关文章
- 【原】FMDB源码阅读(三)
[原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...
- 【原】FMDB源码阅读(二)
[原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...
- 【原】FMDB源码阅读(一)
[原]FMDB源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 说实话,之前的SDWebImage和AFNetworking这两个组件我还是使用过的,但是对于 ...
- 【原】AFNetworking源码阅读(六)
[原]AFNetworking源码阅读(六) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这一篇的想讲的,一个就是分析一下AFSecurityPolicy文件,看看AF ...
- 【原】AFNetworking源码阅读(五)
[原]AFNetworking源码阅读(五) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中提及到了Multipart Request的构建方法- [AFHTTP ...
- 【原】AFNetworking源码阅读(四)
[原]AFNetworking源码阅读(四) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇还遗留了很多问题,包括AFURLSessionManagerTaskDe ...
- 【原】AFNetworking源码阅读(三)
[原]AFNetworking源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇的话,主要是讲了如何通过构建一个request来生成一个data tas ...
- 【原】AFNetworking源码阅读(二)
[原]AFNetworking源码阅读(二) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中我们在iOS Example代码中提到了AFHTTPSessionMa ...
- 【原】AFNetworking源码阅读(一)
[原]AFNetworking源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 AFNetworking版本:3.0.4 由于我平常并没有经常使用AFNetw ...
随机推荐
- POJ 1953 World Cup Noise(递推)
https://vjudge.net/problem/POJ-1953 题意:输入一个n,这n位数只由0和1组成,并且不能两个1相邻.计算共有多少种排列方法. 思路:递推题. 首先a[1]=2,a[2 ...
- 基于贝叶斯优化的超参数tuning
https://arimo.com/data-science/2016/bayesian-optimization-hyperparameter-tuning/ 贝叶斯优化:使用高斯过程作为代理函数, ...
- 磁条卡,IC卡,ID卡,信用卡芯片卡,信用卡磁条卡 等等的区别
1.条码卡:该卡卡面上有一串条码,通过扫描枪或者相应的条码读卡器读出该条码卡的卡号.根据条码的不同又分为39码等其它码.条码卡仅仅是一个编号,不存蓄其它内容.特点:价格便宜类似磁卡. 2.磁条卡:类似 ...
- password_hash加密
每次执行 password_hash('123456', PASSWORD_BCRYPT) 语句后,得到哈希值都不一样! 给密码做哈希之前,会先加入一个随机子串,因为加入的随机子串每次是不一样的,所以 ...
- webdriver 的三种等待方式
1.显式等待 一个显式等待是你定义的一段代码,用于等待某个条件发生然后再继续执行后续代码. from selenium import webdriverfrom selenium.webdriver ...
- 在ANE插件中启动AIR开发的Android应用
在Android原生应用开发中,启动一个应用非常容易: Intent __intent = new Intent(this, YourAppActivity.class); startActivity ...
- js插件---在线类似excel生成图表插件解决方案
js插件---在线类似excel生成图表插件解决方案 一.总结 一句话总结:google比百度好用多了,多用google google js editable table jquery 双向绑定 这种 ...
- TCP三次握手(待细研究)
xu言: 看到一张不错清晰的Tcp三次握手图,收藏 Initiator 发起人 Receiver 接收者 LISTENING 状态xx服务启动后首先处于侦听(LISTENING)状态. ESTAB ...
- codeforces 494a//Treasure// Codeforces Round #282(Div. 1)
题意:一个'(' , ')' , '#'组成的串,可将'#'换成至少一个')'.问一个换法能使串匹配. 至少换成一个,那么就先都换成一个,记结果为str.最后一个')'的后面没有未匹配的'(' ...
- vij 1097 贪心
合并果子 描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之 ...