资讯专栏INFORMATION COLUMN

Zepto源码分析(二)奇淫技巧总结

ygyooo / 1965人阅读

摘要:三目运算符写法如果是结构,会这样写。参数重载个数重载当第二个参数下标是在中,则返回,否则返回。三目运算符写法我们再来看看的版本参数重载类型重载通过来判断是否存在第二个参数,以及通过判断参数的类型执行不同的内容。写法操作中包含部分黑科技。

Zepto源码分析(一)核心代码分析
Zepto源码分析(二)奇淫技巧总结

目录

</>复制代码

  1. * 前言
  2. * 短路操作符
  3. * 参数重载(参数个数重载)
  4. * 参数重载(参数类型重载)
  5. * CSS操作
  6. * 获取属性值的方法
  7. * 获取属性值的方法
  8. * Boolean操作
  9. * 快速转换成Boolean
  10. * 日期操作
  11. * 快速获取时间戳
  12. * 数组操作
  13. * 数组去重
  14. * 数组清洗(去除nullundefined
  15. * 字符串操作
  16. * 快速转换成字符串
  17. * CSS命名方式转驼峰命名方式
  18. * 驼峰转CSS命名方式
  19. * 对象操作
  20. * 在闭包中修改引用会修改原对象
  21. * 对象中的this指向当前的上一个位置
  22. * 判断
  23. * 浏览器类型判断
前言

在Zepto源码中大量使用了三目运算符、短路操作符以及参数重载。要去完整的阅读Zepto源码,理解这几种操作很有必要。

短路操作符

当state为"ready"的时候,把"ok"返回给start。否则返回false给start。

</>复制代码

  1. var state = "ready"
  2. var start = state === "ready" && "ok" // "ok"

三目运算符写法

</>复制代码

  1. var state = "ready"
  2. var start = state === "ready" ? "ok" : false // "ok"

如果是if...else...结构,会这样写。

</>复制代码

  1. var state = "ready"
  2. var start = ""
  3. if (state === "ready") start === "ok" // "ok"
参数重载(个数重载)

当第二个参数(下标是1)在arguments中,则返回"two params",否则返回"one params"。

</>复制代码

  1. var paramsFun = function(a, b) {
  2. return (1 in arguments && "two params") || "one params"
  3. }
  4. paramsFun(2, 4) // "two params"
  5. paramsFun(2) // "one params"

三目运算符写法

</>复制代码

  1. var paramsFun = function(a, b) {
  2. return 1 in arguments ? "two params" : "one params"
  3. }
  4. paramsFun(2, 4) // "two params"
  5. paramsFun(2) // "one params"

我们再来看看if...else的版本

</>复制代码

  1. var paramsFun = function(a, b) {
  2. if(1 in arguments) return "two params"
  3. else return "one params"
  4. }
  5. paramsFun(2, 4) // "two params"
  6. paramsFun(2) // "one params"
参数重载(类型重载)

通过1 in arguments来判断是否存在第二个参数,以及通过判断参数的类型执行不同的内容。

</>复制代码

  1. var paramsFun = function(a, b) {
  2. return (1 in arguments && (typeof a ==="string" ? "two / a is string" : "two / a is not string")) || "one params"
  3. }
  4. paramsFun(2, 4) // "two / a is not string"
  5. paramsFun("", 4) // "two / a is string"

if...else写法

</>复制代码

  1. var paramsFun = function(a, b) {
  2. if(1 in arguments) {
  3. if(typeof a ==="string") return "two / a is string"
  4. return "two / a is not string"
  5. }
  6. return "one params"
  7. }
  8. paramsFun(2, 4) // "two / a is not string"
  9. paramsFun("", 4) // "two / a is string"
CSS操作

Zepto中包含部分CSS黑科技。

获取属性值的方法

非内联CSS我们没法获取到值的,这是可以使用getComputedStyle来获取计算后的样式。

</>复制代码

  1. document.body.style.display // ""
  2. getComputedStyle(document.body, "").getPropertyValue("display") // "block"
添加Style的方法

</>复制代码

  1. element = document.createElement("P")
  2. element.style.cssText += ";color:red;"
  3. element.style.color // "red"
Boolean操作 快速转换成Boolean

使用!!操作可以快速将数据类型转为布尔值。

</>复制代码

  1. !!null // false
  2. Boolean(null) // false
日期操作 快速获取时间戳

使用+new Date()可以快速将日期转为时间戳

</>复制代码

  1. var now = new Date();
  2. console.log(+now) // 1502506825489
  3. console.log(now.getTime()) // 1502506825489
数组操作 数组去重

</>复制代码

  1. var uniq = function(array){ return [].filter.call(array, function(item, idx){ return array.indexOf(item) == idx }) }
  2. uniq([1,2,3,3]) // (3) [1, 2, 3]
数组清洗(去除null和undefined和空字符串)

</>复制代码

  1. function compact(array) { return [].filter.call(array, function(item){ return item != null && item != "" }) }
  2. compact([1,2,3,3,undefined,null,""]) // [1, 2, 3, 3]
字符串操作 快速转换成字符串

</>复制代码

  1. var x = 555
  2. console.log("" + x) // "555"
CSS命名方式转驼峰命名方式

</>复制代码

  1. var camelize = function(str){ return str.replace(/-+(.)?/g, function(match, chr){ return chr ? chr.toUpperCase() : "" }) }
  2. camelize("font-size") // "fontSize"
驼峰转CSS命名方式

</>复制代码

  1. function dasherize(str) {
  2. return str.replace(/::/g, "/")
  3. .replace(/([A-Z]+)([A-Z][a-z])/g, "$1_$2")
  4. .replace(/([a-zd])([A-Z])/g, "$1_$2")
  5. .replace(/_/g, "-")
  6. .toLowerCase()
  7. }
  8. dasherize("fontSize") // "font-size"
对象操作 在闭包中修改引用会修改原对象

对象是引用类型,实际上是修改的被引用的对象。

</>复制代码

  1. var x = {};
  2. (function(y){
  3. y.test = 66
  4. })(x)
  5. console.log(x) // {test: 66}
对象中的this指向当前的上一个位置

这个表述可能不够严谨。在这里是z属性中的this指向了上一层的y,所以this输出了y里面的对象。

</>复制代码

  1. var x = {}
  2. x.y = {}
  3. x.y.z = function(){
  4. console.log(this)
  5. }
  6. x.y.z() // {z: ƒ}
判断 浏览器类型判断

用正则表达式匹配navigator.userAgent中的信息来判断浏览器类型。

</>复制代码

  1. var ua = navigator.userAgent // "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.101 Safari/537.36"
  2. var platform = navigator.platform
  3. var webkit = ua.match(/Web[kK]it[/]{0,1}([d.]+)/),
  4. android = ua.match(/(Android);?[s/]+([d.]+)?/),
  5. osx = !!ua.match(/(Macintosh; Intel /),
  6. ipad = ua.match(/(iPad).*OSs([d_]+)/),
  7. ipod = ua.match(/(iPod)(.*OSs([d_]+))?/),
  8. iphone = !ipad && ua.match(/(iPhonesOS)s([d_]+)/),
  9. webos = ua.match(/(webOS|hpwOS)[s/]([d.]+)/),
  10. win = /Wind{2}|Windows/.test(platform),
  11. wp = ua.match(/Windows Phone ([d.]+)/),
  12. touchpad = webos && ua.match(/TouchPad/),
  13. kindle = ua.match(/Kindle/([d.]+)/),
  14. silk = ua.match(/Silk/([d._]+)/),
  15. blackberry = ua.match(/(BlackBerry).*Version/([d.]+)/),
  16. bb10 = ua.match(/(BB10).*Version/([d.]+)/),
  17. rimtabletos = ua.match(/(RIMsTabletsOS)s([d.]+)/),
  18. playbook = ua.match(/PlayBook/),
  19. chrome = ua.match(/Chrome/([d.]+)/) || ua.match(/CriOS/([d.]+)/),
  20. firefox = ua.match(/Firefox/([d.]+)/),
  21. firefoxos = ua.match(/((?:Mobile|Tablet); rv:([d.]+)).*Firefox/[d.]+/),
  22. ie = ua.match(/MSIEs([d.]+)/) || ua.match(/Trident/[d](?=[^?]+).*rv:([0-9.].)/),
  23. webview = !chrome && ua.match(/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/),
  24. safari = webview || ua.match(/Version/([d.]+)([^S](Safari)|[^M]*(Mobile)[^S]*(Safari))/)

欢迎关注前端进阶指南微信公众号:

另外我也创了一个对应的QQ群:660112451,欢迎一起交流。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/84938.html

相关文章

  • Zepto源码分析(一)核心代码分析

    摘要:源码分析一核心代码分析源码分析二奇淫技巧总结本文只分析核心的部分代码,并且在这部分代码有删减,但是不影响代码的正常运行。当长度为则不添加内容,否则逐个将逐个到当前实例新增直接返回一个新的构造函数添加初始化方法。 Zepto源码分析(一)核心代码分析Zepto源码分析(二)奇淫技巧总结 本文只分析核心的部分代码,并且在这部分代码有删减,但是不影响代码的正常运行。 目录 * 用闭包封装Z...

    BicycleWarrior 评论0 收藏0
  • 2017-08-27 前端日报

    摘要:前端日报精选如何合理地设计的深入了解一个超快的引擎也称全面了解作用域源码分析二奇淫技巧总结整理下前端江湖面试对自己有益的题目。 2017-08-27 前端日报 精选 如何合理地设计Redux的State深入了解一个超快的 CSS 引擎: Quantum CSS (也称 Stylo) ★ Mozilla Hacks全面了解JS作用域Zepto源码分析(二)奇淫技巧总结整理下《前端江湖面试...

    itvincent 评论0 收藏0
  • JavaScript 系列--JavaScript一些奇淫技巧的实现方法()数字格式化;类数组转数

    摘要:一前言之前写了一篇文章系列一些奇淫技巧的实现方法一简短的函数,获取时间戳介绍了函数和获取时间戳的方法。,和对象的构造函数是对象的属性。缺点低版本,无法处理集合的转数组。 一、前言 之前写了一篇文章:JavaScript 系列--JavaScript一些奇淫技巧的实现方法(一)简短的sleep函数,获取时间戳 https://www.mwcxs.top/page/74... 介绍了sle...

    Jrain 评论0 收藏0
  • 前端文档收集

    摘要:系列种优化页面加载速度的方法随笔分类中个最重要的技术点常用整理网页性能管理详解离线缓存简介系列编写高性能有趣的原生数组函数数据访问性能优化方案实现的大排序算法一怪对象常用方法函数收集数组的操作面向对象和原型继承中关键词的优雅解释浅谈系列 H5系列 10种优化页面加载速度的方法 随笔分类 - HTML5 HTML5中40个最重要的技术点 常用meta整理 网页性能管理详解 HTML5 ...

    jsbintask 评论0 收藏0

发表评论

0条评论

ygyooo

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<