jQuery 与 Zepto 的异同

Zepto 最初是为移动端开发的库,是 jQuery 的轻量级替代品,因为它的 API 和 jQuery 相似,而文件更小。

相同

Zepto 最初是为移动端开发的库,是 jQuery 的轻量级替代品,因为它的 API 和 jQuery 相似,而文件更小。Zepto 最大的优势是它的文件大小,只有 8k 多,是目前功能完备的库中最小的一个,尽管不大,Zepto 所提供的工具足以满足开发程序的需要。大多数在 jQuery 中・常用的 API 和方法 Zepto 都有,Zepto 中还有一些 jQuery 中没有的。另外,因为 Zepto 的 API 大部分都能和 jQuery 兼容,所以用起来极其容易,如果熟悉 jQuery,就能很容易掌握 Zepto。你可用同样的方式重用 jQuery 中的很多方法,也可以方面地把方法串在一起得到更简洁的代码,甚至不用看它的文档。

不同

1、针对移动端程序,Zepto 有一些基本的触摸事件可以用来做触摸屏交互(tap 事件、swipe 事件),Zepto 是不支持 IE 浏览器的,这不是 Zepto 的开发者 Thomas Fucks 在跨浏览器问题上犯了迷糊,而是经过了认真考虑后为了降低文件尺寸而做出的决定,就像 jQuery 的团队在 2.0 版中不再支持旧版的 IE(6 7 8)一样。因为 Zepto 使用 jQuery 句法,所以它在文档中建议把 jQuery 作为 IE 上的后备库。那样程序仍能在 IE 中,而其他浏览器则能享受到 Zepto 在文件大小上的优势,然而它们两个的 API 不是完全兼容的,所以使用这种方法时一定要小心,并要做充分的测试。

2、Dom 操作的区别:添加 id 时 jQuery 不会生效而 Zepto 会生效。

(function($) {
     $(function() {
         var $insert = $('<p>jQuery 插入</p>', {
             id: 'insert-by-jquery'
         });
         $insert.appendTo($('body'));
     });
})(window.jQuery);
// <p>jQuery 插入<p>

Zepto(function($) {
    var $insert = $('<p>Zepto 插入</p>', {
        id: 'insert-by-zepto'
    });
    $insert.appendTo($('body'));
});
// <p id="insert-by-zepto">Zepto 插入</p>

3、事件触发的区别:使用 jQuery 时 load 事件的处理函数不会执行;使用 Zepto 时 load 事件的处理函数会执行。

(function($) {
    $(function() {
        $script = $('<script />', {
            src: 'http://cdn.amazeui.org/amazeui/1.0.1/js/amazeui.js',
            id: 'ui-jquery'
        });

        $script.appendTo($('body'));

        $script.on('load', function() {
            console.log('jQ script loaded');
        });
    });
})(window.jQuery);

Zepto(function($) {
    $script = $('<script />', {
        src: 'http://cdn.amazeui.org/amazeui/1.0.1/js/amazeui.js',
        id: 'ui-zepto'
    });

    $script.appendTo($('body'));

    $script.on('load', function() {
        console.log('zepto script loaded');
    });
});

4、事件委托的区别

var $doc = $(document);
$doc.on('click', '.a', function () {
    alert('a事件');
    $(this).removeClass('a').addClass('b');
});
$doc.on('click', '.b', function () {
    alert('b事件');
});

在 Zepto 中,当 a 被点击后,依次弹出了内容为”a 事件 “和” b 事件 “,说明虽然事件委托在.a 上可是却也触发了.b 上的委托。但是在 jQuery 中只会触发.a 上面的委托弹出”a 事件 “。Zepto 中,document 上所有的 click 委托事件都依次放入到一个队列中,点击的时候先看当前元素是不是.a,符合则执行,然后查看是不是.b,符合则执行。而在 jQuery 中,document 上委托了 2 个 click 事件,点击后通过选择符进行匹配,执行相应元素的委托事件。

5、width () 和 height () 的区别

Zepto 由盒模型 (box-sizing) 决定,用.width () 返回赋值的 width,用.css (‘width’) 返回加 border 等的结果;jQuery 会忽略盒模型,始终返回内容区域的宽 / 高 (不包含 padding、border)。

6、offset () 的区别

扫描二维码关注公众号,回复: 15249711 查看本文章

Zepto 返回 {top,left,width,height};jQuery 返回 {width,height}。

7、Zepto 无法获取隐藏元素宽高,jQuery 可以。

8、Zepto 中没有为原型定义 extend 方法而 jQuery 有。

9、Zepto 的 each 方法只能遍历 数组,不能遍历 JSON 对象。

10、Zepto 在操作 dom 的 selected 和 checked 属性时尽量使用 prop 方法,在读取属性值的情况下优先于 attr。Zepto 获取 select 元素的选中 option 不能用类似 jQuery 的方法 $(‘option [selected]’), 因为 selected 属性不是 css 的标准属性。应该使用 $(‘option’).not (function (){ return !this.selected })。

11、Zepto 不支持的选择器

用 jQuery 写插件

;(function($){
  $.fn.extend({
    highLight: function(options){
      if(!isValid(options)){
        return this;
      }
      var opts = $.extend({}, defaults, options);
      return this.each(function(){
        var $this = $(this);
        $this.css({
          backgroundColor: opts.background,
          color: opts.color
        })
        var markup = $this.html();
        markup = $.fn.highLight.format(markup);
        $this.html(markup);
      })
    }
  });
  var defaults = {
    color: '#fff',
    background: '#000'
  };
  $.fn.highLight.format=function(str){
    return '<strong>'+str+'</strong>'
  }
  function isValid(options){
    return !options || (options && typeof options === 'object') ? true: false
  }
})(jQuery)

// 调用
$.fn.highLight.format = function(txt){
  return '<i>'+txt+'</i>'
}
$('p').highLight({ color: 'red', background: '#ccc' })

文章转自博客园,作者:we are youngjQuery 与 Zepto 的异同icon-default.png?t=LA92https://www.cnblogs.com/colima/p/5289386.html

猜你喜欢

转载自blog.csdn.net/godread_cn/article/details/122033771