在浏览器上(Safari、Chrome和Firefox)上开发页面应用或者构建基于html的web-view本地应用,你如PhoneGap,使用Zepto是一个不错的选择。


Jquery和Zepto的区别

由于我原先并没有用过Zepto,所以首先试了一下Jquery和Zepto的区别

1:$(function(){});       J,Z通用,页面加载完毕执行回调函数(Zepto中的$—>Zepto),当然都是可以省略的

2:  Zepto的源码是不加分号的,而Jquery是加分号的!


源码看不懂的地方汇总

1:从this === void 0说起

  1. 二、为什么不直接用undefined 
  2. undefinedJavaScript中并不属于保留字/关键字,因此在IE5.~8中我们可以将其当作变量那样对其赋值(IE9+及其他现代浏览器中赋值给undefined将无效)
  3.  
  4. var undefinedBackup = undefined;
  5. undefined = ;
  6. // 显示"undefined"
  7. console.log(typeof undefinedBackup);
  8. // 在IE5.5~8中显示"number",其他浏览器中则显示"undefined"
  9. console.log(typeof undefined);
  10.  
  11. 于是采用void方式获取undefined则成了通用准则。
  1. 三、一元运算符void的作用 
  2. void的行为特点为:
  3.  
  4.   . 不管void后的运算数是什么,只管返回纯正的undefined
  5.  
  6.   . void会对其后的运算数作取值操作,因此若属性有个getter函数,那么就会调用getter函数(因此会产生副作用)
  7.  
  8. var article = {
  9. _view: ,
  10. get view(){
  11. console.log(this._view);
  12. return this._view++;
  13. }
  14. };
  15. var test = void article.view; // 显示0
  16. console.log(test); // 显示undefined
  17. console.log(article._view); // 显示1
  18.  
  19. 通过一元运算符 delete 作对比,delete的其中一个行为特点是不对其运算数进行取值操作(delete的其他行为特点比我们想的复杂得多,这里就不详细记录了)
  20.  
  21. var article = {
  22. _view: ,
  23. get view(){
  24. console.log(this._view);
  25. return this._view++;
  26. }
  27. };
  28. var ret = delete article.view;
  29. console.log(ret); // 显示true
  30. console.log(article._view); // 显示0

2:浅谈 JS 对象添加 getter与 setter 的5种方法以及如何让对象属性不可配置或枚举

  1. 定义 getter setter
  2.  
  3. .通过对象初始化器在创建对象的时候指明(也可以称为通过字面值创建对象时声明)
  4.  
  5. (function () {
  6. var o = {
  7. a : ,
  8. get b(){return this.a +;},//通过 get,set的 b,c方法间接性修改 a 属性
  9. set c(x){this.a = x/}
  10. };
  11. console.log(o.a);
  12. console.log(o.b);
  13. o.c = ;
  14. console.log(o.a);
  15. })();
  16. chrome 中调试视图如下:
  17.  
  18. 可以看到对象下多了 get 属性以及 set 属性
  19. 输出结果如下:
  20.  
  21. 当然 get 语句与 set 语句可以声明多次用来对应多个 getter setter
  22. 使用这种方法的好处是可以在声明属性的时候同时声明对应的 getter setter
  23. 这里就有人问了,能不能将o 对象的 get set 方法的方法名都改成 a”,这样就可以直接通过“.”来访问方法直接操作
  24.  
  25. (function () {
  26. var o = {
  27. a : ,
  28. get a(){return this.a +;},//死循环
  29. set a(x){this.a = x/}
  30. };
  31. console.log(o.a);
  32. console.log(o.b);
  33. o.c = ;
  34. console.log(o.a);
  35. })();
  36. 打开 chrome 查看创建后的视图如下:
  37.  
  38. 可以看到这个时候的 get set 方法已经和上面不同,但是是否真的能起作用呢,答案是否定的,当我们通过 o.a 调用的是 get语句 声明的 a方法,进入到该方法后遇到 this.a 方法继续调用该方法形成死循环最终导致死循环报内存溢出错误。

3:throw new TypeError()

  1. TypeError(类型错误) 对象用来表示值的类型非预期类型时发生的错误。
  2. 直接写throw new TypeError()会抛出红字错误,并且后面的代码会继续执行!

4:this.length>>>0

  1. Github问了 lifesinger给出了一个this.length >>> 0 的作用更简易的总结:
  2. 所有非数值转换成0
  3. 所有大于等于 0 数取整数部分
  1. 无符号右移运算>>>
  2. 无符号右移运算符由三个大于号(>>>)表示,它将无符号 32 位数的所有数位整体右移。对于正数,无符号右移运算的结果与有符号右移运算一样。
  3. 用有符号右移运算中的例子,把 64 右移 5 位,将变为 2
  4. var iOld = 64; //等于二进制 1000000
  5. var iNew = iOld >>> 5; //等于二进制 10 十进制 2
  6. 对于负数,情况就不同了。
  7. 无符号右移运算用 0 填充所有空位。对于正数,这与有符号右移运算的操作一样,而负数则被作为正数来处理。
  8. 由于无符号右移运算的结果是一个 32 位的正数,所以负数的无符号右移运算得到的总是一个非常大的数字。例如,如果把 -64 右移 5 位,将得到 134217726。如何得到这种结果的呢?
  9. 要实现这一点,需要把这个数字转换成无符号的等价形式(尽管该数字本身还是有符号的),可以通过以下代码获得这种形式:
  10. var iUnsigned64 = -64 >>> 0;
  11. 然后,用 Number 类型的 toString() 获取它的真正的位表示,采用的基为 2
  12. alert(iUnsigned64.toString(2));
  13. 这将生成 11111111111111111111111111000000,即有符号整数 -64 的二进制补码表示,不过它等于无符号整数 4294967232
  14. 出于这种原因,使用无符号右移运算符要小心。

试试看读一下Zepto源码的更多相关文章

  1. 读Zepto源码之代码结构

    虽然最近工作中没有怎么用 zepto ,但是据说 zepto 的源码比较简单,而且网上的资料也比较多,所以我就挑了 zepto 下手,希望能为以后阅读其他框架的源码打下基础吧. 源码版本 本文阅读的源 ...

  2. 读 Zepto 源码之内部方法

    数组方法 定义 var emptyArray = [] concat = emptyArray.concat filter = emptyArray.filter slice = emptyArray ...

  3. 读 zepto 源码之工具函数

    Zepto 提供了丰富的工具函数,下面来一一解读. 源码版本 本文阅读的源码为 zepto1.2.0 $.extend $.extend 方法可以用来扩展目标对象的属性.目标对象的同名属性会被源对象的 ...

  4. 读 Zepto 源码之神奇的 $

    经过前面三章的铺垫,这篇终于写到了戏肉.在用 zepto 时,肯定离不开这个神奇的 $ 符号,这篇文章将会看看 zepto 是如何实现 $ 的. 读Zepto源码系列文章已经放到了github上,欢迎 ...

  5. 读Zepto源码之集合操作

    接下来几个篇章,都会解读 zepto 中的跟 dom 相关的方法,也即源码 $.fn 对象中的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码 ...

  6. 读 Zepto 源码之集合元素查找

    这篇依然是跟 dom 相关的方法,侧重点是跟集合元素查找相关的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码版本 本文阅读的源码为 zept ...

  7. 读Zepto源码之操作DOM

    这篇依然是跟 dom 相关的方法,侧重点是操作 dom 的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码版本 本文阅读的源码为 zepto1 ...

  8. 读Zepto源码之样式操作

    这篇依然是跟 dom 相关的方法,侧重点是操作样式的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码版本 本文阅读的源码为 zepto1.2. ...

  9. 读Zepto源码之属性操作

    这篇依然是跟 dom 相关的方法,侧重点是操作属性的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码版本 本文阅读的源码为 zepto1.2. ...

随机推荐

  1. 2010-01-20 12:09 ubuntu下minicom的安装及使用

    转http://hi.baidu.com/npugtawqdnbgqrq/item/106f805409b42813db163527 ubuntu下minicom的安装及使用 安装: sudo apt ...

  2. vicoapp使用备忘

    vico是一个模式编辑器,意味着没用过vi之类编辑器的童鞋用起来肯定觉得很不习惯. 模式切换 i:切至编辑模式,在光标前插入 a:切至编辑模式,在在光标后插入 I:类似于i,不过在行首插入 esc键: ...

  3. Spring Boot缓存应用实践

    缓存是最直接有效提升系统性能的手段之一.个人认为用好用对缓存是优秀程序员的必备基本素质. 本文结合实际开发经验,从简单概念原理和代码入手,一步一步搭建一个简单的二级缓存系统. 一.通用缓存接口 1.缓 ...

  4. 【转载】tomcat+nginx+redis实现均衡负载、session共享(一)

    http://www.cnblogs.com/zhrxidian/p/5432886.html 在项目运营时,我们都会遇到一个问题,项目需要更新时,我们可能需先暂时关闭下服务器来更新.但这可能会出现一 ...

  5. redis+twemproxy实现redis集群

    Redis+TwemProxy(nutcracker)集群方案部署记录 转自: http://www.cnblogs.com/kevingrace/p/5685401.html Twemproxy 又 ...

  6. 在vs2013下手把手创建/调用dll

    body { font: 16px } 参考了大佬的文章 首先,体会一下静态编译: 创建Win32Project,选DLL,添加一个.h和.cpp文件 点击生成解决方案,然后去debug目录下拷贝.l ...

  7. Vue 仿B站滑动导航

    仿照B站制作的滑动导航功能,进行了部分优化,例如可定制默认选中元素,并将选中元素居中显示,可动态更改数据,可定制回调函数取的下标和选中元素内容,可根据需求制作N级联动 已开发成插件,使用方法与源码请前 ...

  8. 重装完的win10卡“请稍等”,然后电脑不断自动重启还是卡在“请稍等”?

    http://bbs.pcbeta.com/viewthread-1625778-1-1.html 说实话我用U盘安装win10遇到过几次这种情况,不管是win10正式版还是之前的个别win10测试版 ...

  9. Python学习摘要201802

    [基础]变量设计机制 [个人理解]python的变量与C++语言中的指针类似,是指向内存数据的一个引用.变量分为不可变变量string/int/float/tuple和可变变量list/dict. 对 ...

  10. sql server 多行数据合并成一列

    首先是源数据: ),cip.CheckIn_StartTime, )),cip.CheckIn_EndTime, )),cip.Rental_Price)) as content from Check ...