JQuery模块分析及其实现第四部分属性部分功能及实现,接第三部分!
appendTo 方法
- 功能:将结果集中的元素 追加到指定的
dom元素上. - 语法:
<target对象>.appendTo(target) - 实现思路
- 定义
appendTo方法,声明一个形参target.追加到目标dom元素- 选择器
dom元素dom数组
- 为了操作方便,将
target类型统一为itcast对象,去itcast函数走一圈,出来就是itcast对象. - 遍历
this上的每一个dom元素,再遍历target上的每一个dom元素 - 将
this上的dom元素追加到target上 - 注意:
在追加节点时,如果遍历的是第一个目标dom元素,不需要拷贝节点;否则要深拷贝节点,并将上述得到的节点储存到ret内 - 将
ret数组转换成itcast对象,作为appendTo方法的返回值- 如果不这样做的话,就会在添加样式时,只有没拷贝的节点有样式
- 定义
1 | appendTo: function(target) { |
append 方法
- 语法:
<itcast对象>.append(source); - 功能: 将
source上的所有dom元素,追加到itcast对象上 - 实现思路
- 统一
source类型,为itcast对象. source.appendTo(this)return this;
- 统一
1 | append: function(source) { |
prependTo 方法
- 语法:
<itcast对象>.prependTo(target); - 功能:将
itcast对象上的每一个dom元素,追加到target最前边insertBefore - 实现思路
- 统一
target类型,为itcast对象 - 定义
node变量,临时存储被追加的结点.定义ret数组,存储所有被追加的节点 - 先遍历
target上的每一个dom元素 - 定义变量
firstChild,临时存储当前目标dom元素的第一个子节点,再遍历this上的每一个dom元素 - 判断当前遍历的
dom是否为target上的第一个dom元素 - 如果为真,此时不需要克隆节点
- 否则,要深克隆节点
- 将上述的到的节点,
push到ret内 - 调用
insertBefore方法追加节点,此时第一个参数为追加新的节点,第二个参数为firstChild,在firstChild之前追加新节点. - 两层循环结束,操作完成
- 将
ret转换成itcast对象,作为prependTo方法的返回值,实现链式编程.
- 统一
1 | prependTo: function(target) { |
prepend 方法
- 语法:
<itcast对象>.prepend(source); - 功能:把
source上的所有的dom元素,添加到this上的最前边 - 实现思路:
- 统一
source类型,为itcast对象 - 通过
source调用prependTo方法,将source上的所有dom添加到this上的最前边 -
return this实现链式编程
- 统一
1 | prepend: function(source) { |
next 方法
- 功能:获取
itcast对象上所有dom元素的下一个兄弟元素(nextSiling) - 语法:
<itcast对象>.next();返回值类型,itcast对象 - 实现思路
- 定义
ret数组,存储所有dom的下一个兄弟元素 - 遍历
this上的所有dom元素 - 遍历当前
dom元素下面的所有兄弟,如果类型为 元素,将此元素存储ret内,结束循环。 - 两层循环结束,将
ret转换成itcast对象,作为next方法的返回值。
- 定义
1 | next: function() { |
nextAll
- 功能:获取
itcast对象上所有dom元素下面的所有兄弟元素(nextSiling) - 语法:
<itcast对象>.nextAll();返回值类型,itcast对象 - 实现思路
- 定义
ret数组,存储所有dom的下一个兄弟元素 - 遍历
this上的所有dom元素 - 遍历当前
dom元素下面的所有兄弟,如果类型为 元素,将此元素存储ret内,结束循环。 - 两层循环结束,将
ret转换成itcast对象,作为nextAll方法的返回值。
- 定义
1 | nextAll: function() { |
before 方法
- 功能:
- 语法:
<itcast对象>.before(source) - 实现思路
- 统一
source类型为itcast对象 - 遍历
this上的每一个dom元素 - 再遍历
source上的每一个dom元素 - 判断当前遍历
this的dom元素的索引是否为0 - 如果是
0,不需要拷贝节点 - 否则要深拷贝节点
- 先拿到当前遍历
this的dom元素的父节点,调用insertBefore方法在其前面添加上面的到的新节点 - 两层循环完毕,操作完成
-
return this实现链式编程
- 统一
1 | before: function(source) { |
after 方法
- 功能:
- 语法:
<itcast对象>.after(source) - 实现思路
- 定义
nextSiling变量,存储dom元素的下一个兄弟节点 - 统一
source类型为itcast对象 - 遍历
this上的每一个dom元素 - 再遍历
source上的每一个dom元素 - 判断当前遍历
this的dom元素的索引是否为0 - 如果是
0,不需要拷贝节点 - 否则要深拷贝节点
- 先拿到当前遍历
this的dom元素的父节点,调用insertBefore方法在其前面添加上面的到的新节点 - 两层循环完毕,操作完成
-
return this实现链式编程
- 定义
1 | after: function(source) { |
unique 方法
- 功能:实现数组元素去重
- 语法:
var newRet = itcast.unique(arr); - 实现思路
- 定义空数组对象
ret.存储去重后的元素 - 遍历原数组,如果当前遍历到的元素在
ret中不存在,就添加ret内 - 循环结束,
ret存储的就是去重后的元素 - 返回
ret
- 定义空数组对象
- 兼容IE8 indexof 方法
- 首先判断当前浏览器是否支持
indexof方法 - 如果不支持就给数组对象的原型添加
indexof方法 - 遍历
this上的所有元素 - 如果遍历到的当前元素和指定参数值相同就直接返回其索引值.结束循环
- 如果在整个上述循环都没有返回值,那么表示不存在指定参数值就返回
-1.
- 首先判断当前浏览器是否支持
1 | unique: function(arr) { |
兼容 `IE8` `indexof` 方法
1 | // 兼容数组对象的indexOf方法 |
prev 方法
- 功能: 获取
itcast对象上所有dom元素的前一个兄弟元素(previousSibling) - 语法:
<itcast对象>.prev();返回值类型:itcast对象 - 实现思路
- 定义
ret数组,存储所有dom的前一个兄弟元素 - 遍历
this上的所有dom元素 - 遍历当前
dom元素之前的所有兄弟,如果类型为元素,将此元素存储ret内,结束循环 - 两层循环结束,将
ret转换成itcast对象,作为next方法的返回值
- 定义
1 | prev:function(){ |
prevAll 方法
- 功能: 获取
itcast对象上所有dom元素的之前的所有兄弟元素(nextSibling) - 语法:
<itcast对象>.nextAll();返回值类型:itcast对象 - 实现思路
- 定义
ret数组,存储所有dom之前的所有兄弟元素 - 遍历
this上的所有dom元素 - 遍历当前
dom元素之前的所有兄弟,如果类型为元素,将此元素存储ret内,结束循环 - 两层循环结束,将
ret转换成itcast对象,作为nextAll方法的返回值
- 定义
1 | prevAll:function(){ |