jQuery源代码学习笔记_工具函数_noop/error/now/trim
jQuery源代码学习笔记_工具函数_noop/error/now/trim
jquery提供了一系列的工具函数,用于支持其运行,今天主要分析noop/error/now/trim这4个函数:
1.noop
//返回一个空函数
function noop() {
}
noop这个函数的功能就是什么也不做,方便在全局使用一个空函数,减少内存开销。
2.error
function error(msg) {
throw new Error(msg);
}
用于统一抛出异常,可以减少代码中使用throw/new,降低使用要求。
JS的异常处理
TODO
3.now
function now() {
return +(new Date());
}
用于返回当前的时间戳。注意返回结果使用"+"转换成数字(Number)
JS基础类型的优雅类型转换
在JS中基本的值类型Boolean、Number和String可以通过调用其构造函数的方式来进行相互转换。eg: var num = Number(str);但是这样的写法无疑不够优雅,对于这三者之间的类型转换,我们可以如下处理。
Boolean、String和Date转换成数字:
不能使用parseInt 和parseFloat两个函数来进行转换,这两个函数会转换字符串开头的有效数字。优雅的写法应当是使用"+"号,同时在数学运算中"-"、"*"、"/"和"%"都可以用于进行数字转换,如果原对象不能转换成数字,返回NaN。
Number和Boolean转换成String:
优雅的写法应当是写成'' + 变量。
Number和String转换成Boolean:
优雅的写法是!!变量,如果本来就取反义,那就写一个!。
前几日在看fex-team的源代码,函数里面用到的类型转换写法不太优雅,下面是其中截取的代码片段:

分析:
- count>=max(红色框)用到两次,是不是应该变量缓存
- 最后一句return(红色下划线)有点复杂化了,因为count>=max的结果就是boolean类型,而采用三元运算符方法和count>=max的结果是相反的,那么直接可以用!(非)即可。
针对上面延伸理解JS优雅的类型转换规则第3点:我觉得比较优雅的写法应该是:
var a = count >= max;
if (a && flag) {
flag = false;
this.trigger('error', 'Q_EXCEED_NUM_LIMIT', max, file);
setTimeout(function () {
flag = true;
},
1);
}
return !a;
});
再看文中的下面一段代码,相比之前已经很好了(蓝色框是相对上面改善的改变体现)

至少这里已经把变量缓存了,同样道理,我觉得比较优雅的写法应该是:!invalid代替原来的三元运算符
uploader.on('beforeFileQueued', function (file) {
var invalid = count + file.size > max;
if (invalid && flag) {
flag = false;
this.trigger('error', 'Q_EXCEED_SIZE_LIMIT', max, file);
setTimeout(function () {
flag = true;
},
1);
}
return !invalid;
});
4.trim
var rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g; //正则表达式要理解,BOM就是字节FEFF。
function trim(text) {
return text == null ? "" : (text + "").replace(rtrim, "");
}
用于去除字符串两边的空白字符和BOM
UTF-8 BOM是什么?
我们看到百度百科里面关于BOM的介绍如下:
如果您在修改任何PHP文件後发生:
- 不能登入或者不能登出;
- 页顶出现一条空白;
- 页顶出现错误警告;
- 其它不正常的情况。
则多半是编辑器的问题,本程序采用UTF-8编码。现在几乎所有的文本编辑软件都可以显示并编辑UTF-8编码的文件。类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM,转换成Unicode为FEFF)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,BOM是个大麻烦。
PHP并不会忽略BOM,所以在读取、包含或者引用这些文件时,会把BOM作为该文件开头正文的一部分。根据嵌入式语言的特点,这串字符将被直接执行(显示)出来。由此造成即使页面的 top padding 设置为0,也无法让整个网页紧贴浏览器顶部,因为在html一开头有这3个字符呢!
总结起来就是:linux的UTF-8是没有前缀的,而Windows默认使用ASCII码,所以UTF-8文件前面会有一个前缀FEFF,三个字节来标注自己是UTF-8文件,而浏览器大多不会对Windows特殊优化,所以会认为这三个字节是有效内容,浏览器很多时候会使用GBK或者Unicode这样的双字节编码,在前面加上奇数个字节会造成全文不可读,所以很多时候,我们要求网页不能有BOM。
一言以蔽之:BOM只有Windows系统认识,浏览器不认识。
jQuery源代码学习笔记_工具函数_noop/error/now/trim的更多相关文章
- jQuery源代码学习笔记_01
如何获取jQuery源代码 1.可以从GitHub上下载到没有合并和压缩的源代码 2.如果要查看兼容IE6-8的版本,请选择1.x-master分支 3.可以使用git clone也可以使用downl ...
- jQuery源代码学习笔记:jQuery.fn.init(selector,context,rootjQuery)代码具体解释
3.1 源代码 init: function( selector, context, rootjQuery ) { var match, elem, ret, doc; // Handle $(&qu ...
- jQuery源代码学习笔记:构造jQuery对象
2.1源代码结构: (function( window, undefined ) { var jQuery = (function() { // 构建jQuery对象 var jQuery = fun ...
- jQuery源代码学习笔记_bind
一般想到JS的兼容性问题的时候,首先会想到addEventListener与attachEvent这一对冤家,那么我们先来看看它们有什么兼容性问题 addEventListener与attachEve ...
- jQuery源代码学习_工具函数_type
jquery源代码学习_工具函数_type jquery里面有一个很重要的工具函数,$.type函数用来判断类型,今天写这篇文章,是来回顾type函数的设计思想,深入理解. 首先来看一下最终结果: 上 ...
- OpenCV 学习笔记03 findContours函数
opencv-python 4.0.1 1 函数释义 词义:发现轮廓! 从二进制图像中查找轮廓(Finds contours in a binary image):轮廓是形状分析和物体检测和识别的 ...
- canvas学习笔记、小函数整理
http://bbs.csdn.net/topics/391493648 canvas实例分享 2016-3-16 http://bbs.csdn.net/topics/390582151 html5 ...
- [Java] LinkedList / Queue - 源代码学习笔记
简单地画了下 LinkedList 的继承关系,如下图.只是画了关注的部分,并不是完整的关系图.本博文涉及的是 Queue, Deque, LinkedList 的源代码阅读笔记.关于 List 接口 ...
- IOS学习笔记07---C语言函数-printf函数
IOS学习笔记07---C语言函数-printf函数 0 7.C语言5-printf函数 ------------------------- ----------------------------- ...
随机推荐
- sizeof的用法与字节对齐
一.sizeof是什么? sizeof是一种预编译处理,不是函数,不是一元表达式.也即,作用阶段在编译期. 二.功能是什么? sizeof返回变量或类型的字节数. 三.调用方式 sizeof(obje ...
- VTK-py读取与显示相关函数
在VTK中可视化数据的一般流程如下: 文件输入相关函数: https://www.vtk.org/Wiki/VTK/Examples/Cxx#Input_and_Output Readers ● Re ...
- Automake基本用法
一. 确认你的系统安装有GNU的如下软件: 1. automake2. autoconf3. m44. perl5. 如果你需要产生共享库(shared library)则还需要GNU Libtool ...
- Vue知识分享一
最近想着把之前学的Vue的知识整理一下,方便在公司和同事一起分享.我想要按照下面几个方面去说一下,我对vue的学习理解. 一.什么是VUE vue.js是一个用来开发Web界面的前端库,是很轻量级的工 ...
- Spark大数据处理 之 RDD粗粒度转换的威力
在从WordCount看Spark大数据处理的核心机制(2)中我们看到Spark为了支持迭代和交互式数据挖掘,而明确提出了内存中可重用的数据集RDD.RDD的只读特性,再加上粗粒度转换操作形成的Lin ...
- QueryTask,FindTask,IdentifyTask三种查询的区别
1:QueryTask是一个进行空间和属性查询的功能类,它可以在某个地图服务的某个子图层内进行查询,顺便需要提一下的是,QueryTask进行查询的地图服务并不必项加载到Map中进行显示.QueryT ...
- 再谈hive-1.0.0与hive-1.2.1到JDBC编程忽略细节问题
不多说,直接上干货,这个问题一直迷惑已久,今天得到亲身醒悟. 所以,建议hadoop-2.6.0.tar.gz的用户与hive-1.0.0搭配使用.当然,也可以去用高版本去覆盖它. log4j:WAR ...
- Qt 学习之路 2(6):Qt 模块简介
Home / Qt 学习之路 2 / Qt 学习之路 2(6):Qt 模块简介 豆子 2012年8月26日 Qt 学习之路 2 20条评论 Qt 5 与 Qt 4 最大的一个区别之一是底层架构 ...
- Subversion Server Edge的安装使用
1.Subversion Server Edge的搭建 当在操作系统为64位的配置服务器上部署时只能够选择Collabnet Subversion Edge,它集合了Subversion所需要一切资源 ...
- Ubuntu 16.04设置root用户登录图形界面
ubuntu桌面版默认不开启root登录,所以需要进行设置, 可以参考博客 https://www.linuxidc.com/Linux/2017-01/139094.htm