zepto.js 不支持eq吗
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了zepto.js 不支持eq吗相关的知识,希望对你有一定的参考价值。
参考技术A polyfill,zepto,detect,event,ajax,form,fx 这7个就是标准版包含的模块fx_methods 有了这个模块之后,.show() .hide() 等几个方法才能支持动画了,比如 .show('fast')
data 提供对 .data() 方法的完整支持,像 jQuery 一样用内存对象存储
assets 移除 img 元素后做一些特殊处理,用来清理内存
selector 更多的选择器的支持,后面会提到
touch 对触摸事件的支持,比如 tap 事件
如果你对 Node 不了解不知道如何 Build 的话,可以下载我的版本
不要用 click 事件,用 tap 代替
这个估计已经广为人知了,因为 click 事件有 200~300 ms 的延迟,为了更快的响应,最好用 Zepto 提供的 tap 事件
不相信的话,可以用以下代码测试一下
var t1,t2;
$('#id').tap(function ()
t1 = Date.now();
);
$('#id').click(function ()
t2 = Date.now();
alert(t2 - t1);
);
Zepto 对 CSS 选择器的支持
郑重提醒,:text :checkbox :first 等等在 jQuery 里面很常用的选择器,Zepto 不支持!
原因很简单,jQuery 通过自己编写的 sizzle 引擎来支持 CSS 选择器,而 Zepto 是直接通过浏览器提供的 document.querySelectorAll 接口。
这个接口只支持标准的 CSS 选择器,而上面提到的那些属于 jQuery 选择器扩展,所以仔细看看这个网页,注意一下这些选择器。
当然也有好消息,就是上面提到的 selector 模块,如果有这个模块的话,能够支持 部分 的 jQuery 选择器扩展,列举如下:
:visible :hidden
:selected :checked
:parent
:first :last :eq
:contains :has
元素的尺寸计算
首先 Zepto 没有 .innerHeight() .outerWidth() 等四个方法,其次,它的 .height()/.width() 方法也不完善,对于 display:none 的元素,计算出的高宽都是 0
而这在 jQuery 里面是没有问题的,因为 jQuery 针对这种元素,会先设置其 css 样式设置为position: "absolute", visibility: "hidden", display: "block"
计算完高宽后再恢复,参见 https://github.com/jquery/jquery/blob/master/src/css.js#L460
如果遇到这种特殊情况,可以参考 jQuery 写一个类似的方法
.prop() 方法的陷阱
有次我要把一个文本框置为只读,写了这么一行 $('#text').prop('readonly', true) 结果死活不工作
找了半天才发现,正确的写法是这样 $('#text').prop('readOnly', true) ,如果你居然看不出两者的差别,那么悄悄提示你:注意大小写!
翻了一下相关的文档,原来只读属性的正确拼法确实是 readOnly,可是在 jQuery 里面上一段代码却能正常工作
于是到 jQuery 源码里面一找才发现,还有这么一段 https://github.com/jquery/jquery/blob/master/src/attributes.js#L466
jQuery.each([
"tabIndex",
"readOnly",
"maxLength",
"cellSpacing",
"cellPadding",
"rowSpan",
"colSpan",
"useMap",
"frameBorder",
"contentEditable"
], function()
jQuery.propFix[ this.toLowerCase() ] = this;
);
从这里也能看到,jQuery 的成熟度真是难以超越,因为他把我们都惯坏了……
考虑到这段代码比较简单,我厚颜无耻地抄袭了一下然后给 Zepto 提了一个 pull request ,如果你们喜欢这种无脑的用法,可以去评论表达支持(记得用英文)
.show() 的动画效果
如果没有 fx_mehods 模块的话,.show() 方法是不支持动画的,不过有了这模块后,动画的支持还是有点小问题,比如这么一段 html
<div style="background:black;opacity:0.7;display:none">
test
</div>
如果你调用 $('div').show('fast') ,那么动画完成后你看到的不会是一个半透明的元素,而是全黑不透明的
因为 Zepto 的 .show() 动画实现的很简单,没有高宽的变化,而是将透明度从 0 逐渐变为 1,所以元素上原来设置的透明度就被替代了。
这种情况下,可以用 .fadeIn() 方法来替代 .show()
:在 Zepto.js 中选择
【中文标题】:在 Zepto.js 中选择【英文标题】::selected in Zepto.js 【发布时间】:2012-02-25 12:51:11 【问题描述】:在 Zepto.js 中执行 .find("option:selected") 时出现错误。 Zepto 甚至支持 ":selected" 吗?如果没有,是否有一种等效的方法可以使该工作正常工作,而无需恢复为 jQuery?
【问题讨论】:
【参考方案1】:通过浏览文档,我不这么认为。也就是说,您应该能够做到:
var sel = document.getElementById("mySelect");
console.log(sel.options[sel.selectedIndex].value);
【讨论】:
谢谢!我一直忘记“常规”JavaScript。 =)【参考方案2】:Zepto 的默认模块不支持 :selected,因为它不是 CSS 标准,但您可以为该功能添加“选择器”Zepto 模块(请参阅Zepto Github page 以使用可选模块构建库)。
或者,Zepto 问题中提到了这种解决方法:https://github.com/madrobby/zepto/issues/503
// get OPTION elements for which `selected` property is true
$('option').not(function() return !this.selected )
【讨论】:
【参考方案3】:试试$('select').val();
这似乎对我有用。
【讨论】:
【参考方案4】:$("#YOURselectID").val();
应该可以正常工作。
:selected
也不能正常工作 zeptoJS
您也可以试试这个来获取所选项目的文本。
$("#YOURselectID option["+$("#YOURselectID").val()+"]").html();
应该可以正常工作。
格式为$(ID option[value]).html();
【讨论】:
【参考方案5】:$('option:checked')
在我的项目中,我用上面的代替。
demo
【讨论】:
以上是关于zepto.js 不支持eq吗的主要内容,如果未能解决你的问题,请参考以下文章
使用 jQuery 方法扩展 Zepto.js?滚动顶部()