zepto源码--核心方法10(位置)--学习笔记
今天基本上就是zepto学习笔记的最后一篇了,介绍一下有关位置的函数,position, offset, scrollLeft, scrollTop
scrollLeft

如果所选取的包装集不存在,则直接返回。
定义变量:
var hasScrollLeft = 'scrollLeft' in this[0]
在zepto中用到了很多类似的特性检测的方法,判断浏览器是否支持scrollLeft这一特性,如果支持,则直接使用该特性,如果不支持,则利用其他方法来实现。
这里是在判断浏览器是否支持scrollLeft这一特性。
这之后就是实现函数的目的,获取当前水平滚动的距离,或者设置水平滚动的距离。
if (value === undefined) return hasScrollLeft ? this[0].scrollLeft : this[0].pageXOffset
如果没有传入参数,就表示获取滚动距离,依据hasScrollLeft的布尔值,决定获取的方法,如果hasScrollLeft为真,直接获取this[0].scrollLeft;否则获取this[0].pageXOffset。
pageXOffset 返回当前页面相对于窗口显示区左上角的 X 位置。
return this.each(hasScrollLeft ?
function(){ this.scrollLeft = value } :
function(){ this.scrollTo(value, this.scrollY) })
设置水平滚动距离时,需要对包装集遍历,也需要依据hasScrollLeft,如果hasScrollLeft=true,则将传入的value直接赋值给this.scrollLeft;否则利用javascript的原生函数scrollTo(x, y),向左滚动将x改为value,y保持原有高度不变。
scrollTo() 方法可把内容滚动到指定的坐标。

scrollTop

该函数与scrollLeft完全一致,唯一的区别就是将水平滚动,改为垂直滚动距离,不再详细介绍。
offset

也属于获取和设置使用的同一个函数,依据是否传入参数,判断是获取还是设置。
zepto的API解释:
获得当前元素相对于document的位置。返回一个对象含有: top, left, width和height
当给定一个含有left和top属性对象时,使用这些值来对集合中每一个元素进行相对于document的定位。
如果coodinates存在,即传入了参数,则表示设置,依据源码来看,只能设置当前包装集的left和top值,传入的参数是包含left和top属性的一个对象。
遍历包装集, 对包装集内的每一个元素单独应用该方法。
var $this = $(this)
需要对传入的参数coodinates进一步处理,允许用户传入函数形式,利用funcArg函数,将其转换为我们需要的格式。即使插入的参数是函数,最终返回结果也必须是包含top和left属性的对象。
coords = funcArg(this, coordinates, index, $this.offset()),
由于定位都是相对于最近的一个具有定位属性的父元素来设置位置的,所以这里必须获取最近的一个有定位的父元素的位置,以修正实际位置,使得该函数相对于document定位。
parentOffset = $this.offsetParent().offset(),
这里利用到了offset获取元素位置的功能,而offsetParent在上篇文章中刚刚介绍。
之后就是确定需要设置的真正的left和top 的值,
props = {
top: coords.top - parentOffset.top,
left: coords.left - parentOffset.left
}
由于目的是设置相对于document的定位,所以这里是修正实际需要给元素赋值的距离。
准备工作做完,就是设置的具体实现了,其实到了这里就已经很简单了,利用之前定义的css函数,$this.css(props),需要注意的是,要想使定位发生作用,就必须给元素设置position属性为relative, absolute, fixed这三者中的一个。所以在调用css函数之前,需要对当前元素的postion进行判断,如果是static,就必须将其改为relative。
如果没有传入有效参数,则是该函数的另外一个需要实现的功能,获取当前包装集中第一个元素的位置信息,包括left,top,width,height。
判断包装集,如果包装集不存在,直接返回null。
判断包装集选择的是否是document对象,如果选中的是document对象,直接返回{top: 0, left: 0}
否则调用调用JavaScript原生函数 getBoundingClientRect(),该方法返回元素的大小及其相对于视口的位置。包含6个属性,left,top,right,bottom,width,height。
最后返回我们需要的内容
return {
left: obj.left + window.pageXOffset,
top: obj.top + window.pageYOffset,
width: Math.round(obj.width),
height: Math.round(obj.height)
}
由于我们需要获取的是相对于document的位置,所以需要对left进行修正,加上window.pageXOffset或者window.pageYOffset。
pageXOffset 设置或返回当前页面相对于窗口显示区左上角的 X 位置。pageYOffset 设置或返回当前页面相对于窗口显示区左上角的 Y 。
position

获取对象集合中第一个元素的位置。相对于 offsetParent。与offset的区别:只作为获取对象集合中第一个元素的位置,即获取left和top值,实际上类似于css中的position定位的意思,但是这里只有获取功能,而不存在设置的功能。也没有width和height,不可混淆。
在理解了offset函数的基础上来看,这个函数相对容易理解很多,其实就是获取当前包装集中第一个元素的offset和offsetPrent的offset,两者相减即可。中间有对部分浏览器的offset的修正,我认为知道即可。
至此,zepto源码学习,基本上算是完成了,等到后面对JavaScript有更深一层次的把握之后,希望有时间来回头从整体上重新整理一下zepto源码学习。
也还有很多自己并不理解的地方,学习笔记的最重要的目的,是记录自己对于zepto源码的一点点学习,如果有错误或者不详尽的地方,读者能够给予指正,不胜感激。
关于zepto插件部分的源码,一概没有涉及,包括zepto源码在最后面直接包含的插件部分,如ajax,事件处理等等,均未在这一阶段涉及。
zepto源码--核心方法10(位置)--学习笔记的更多相关文章
- zepto源码--核心方法(类数组相关)--学习笔记
从这篇起,在没有介绍到各类插件之前,后面将陆续介绍zepto对外暴露的核心方法.即$.fn={}里面的所有方法的介绍.会配合zepto的API进行介绍. 其实前面已经介绍了几个,如width,heig ...
- zepto源码--几个判断函数--学习笔记
几个需要经常用到的类型判断: 自定义一个类似于typeof的函数,提供更多的类型判断. class2type[toString.call(obj)] 是对class2type的取值 在后面通过循环对c ...
- zepto源码--核心方法9(管理包装集)--学习笔记
今天介绍的是与子元素相关的函数,children, find, contents children 从源码来看,主要是调用过滤函数filtered对遍历整个包装集返回的children进行过滤. 仔细 ...
- zepto源码--核心方法7(管理包装集)--学习笔记
后面应该会有几篇连续介绍关于zepto包装集的文章.涉及的函数较多,就分别介绍,今天介绍几个使用关系获取包装集的方法.prev, next, first, last, siblings, eq pre ...
- zepto源码--核心方法5(文本操作)--学习笔记
涉及到文本内容的主要有三个函数:html, text, val. 我们已经见过多次,一个函数多种用途的情况,今天这三个函数也不例外,既可以获取内容,也可以设置内容.判断条件就是有没有传入参数,如果没有 ...
- zepto源码--核心方法4(包装)--学习笔记
主要介绍一下wrap, wrapAll, wrapInner, unwrap方法. wrapAll 在所有匹配元素外面包一个单独的结构.结构可以是单个元素或 几个嵌套的元素,并且可以是html字符串或 ...
- zepto源码--核心方法3(属性相关)--学习笔记
继续$.fn方法 今天主要介绍几个跟属性操作相关的方法attr, removeAttr, prop, data attr 读取或设置dom的属性.如果没有给定value参数,则读取对象集合中第一个元素 ...
- zepto源码--核心方法8(管理包装集)--学习笔记
继续包装集过滤的相关函数的介绍,今天介绍与父元素相关的函数,parent, parents, closest, offsetParent parent 获取对象集合中每个元素的直接父元素. 与上篇文章 ...
- zepto源码--核心方法6(显示隐藏)--学习笔记
在不引入zepto插件模块fx_metho其他ds的情况下,zepto默认的显示隐藏的函数只有show, hide, toggle,这里解释有个前提条件,就是没有引入zepto的fx_methods插 ...
随机推荐
- tomcat与HTML命令提示符
在tomcatwebapps目录下建立一个新文件夹 命名为my 把第一个学习的HTML文件放到my文件夹内 通过tomcat服务器远程访问该网页 把localhost换成自己的IP地址 先查看自己的I ...
- EF框架step by step(2)—Model-First
这一篇主要说一下EF框架中,Model First做法,仍然采用上一篇的案例.但增加评论功能.首先打开Blog.edmx文件,在空白处右键,添加新实体Comment,如下图示: 点击确定,关闭窗口. ...
- C#资源文件与与资源名称字符串之间的互相转化
1.使用ResourceManager string st = Properties.Resources.ResourceManager.GetString(tableName);value = Pr ...
- 【原】iOS学习46之第三方CocoaPods的安装和使用(通用方法)
本文主要说明CocoaPods的安装步骤.使用说明和常见的报错即解决方法. 1. CocoaPods 1> CocoaPods简介 CocoaPods是一个用来帮助我们管理第三方依赖库的工具. ...
- BZOJ1894 : Srm444 avoidfour
首先只有质数个$4$且个数不超过$10$的限制条件才有用, 也就是长度不能为$44,444,44444,4444444$的倍数. 考虑容斥,计算长度必须是它们$lcm$的倍数,且没有连续$4$个$4$ ...
- BZOJ4568 : [Scoi2016]幸运数字
树的点分治,每次求出重心后,求出重心到每个点路径上的数的线性基. 对于每个询问,只需要暴力合并两个线性基即可. 时间复杂度$O(60n\log n+60^2q)$. #include<cstdi ...
- 相遇点对 & 数点问题
题意: 一个长为l的环,环上有n个点,每个点以一定的速度顺时针或逆时针运动,两个点相遇即某一时刻内两个点位置相同. 求有多少点对相遇----相同点对出现多次仅统计一次. SOL: 考试的时候想到用线段 ...
- HDU 2846 (AC自动机+多文本匹配)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2846 题目大意:有多个文本,多个模式串.问每个模式串中,有多少个文本?(匹配可重复) 解题思路: 传统 ...
- Redis的两个小技巧
1.通配删除相同前缀的缓存 DEL命令的参数不支持通配符,但我们可以结合Linux的管道和xargs命令自己实现删除所有符合规则的键. 比如要删除所有以“structure_”开头的键,就可以执行下面 ...
- 51Nod 1079 中国剩余定理 Label:数论
一个正整数K,给出K Mod 一些质数的结果,求符合条件的最小的K.例如,K % 2 = 1, K % 3 = 2, K % 5 = 3.符合条件的最小的K = 23. Input 第1行:1个数 ...