jQuery的XX如何实现?——4.类型检查

往期回顾:

jQuery的XX如何实现?——1.框架

jQuery的XX如何实现?——2.show与链式调用

jQuery的XX如何实现?——3.data与cache机制

--------------------------

源码链接:内附实例代码

jQuery使用许久了,但是有一些API的实现实在想不通。于是抽空看了jQuery源码,现在把学习过程中发现的一些彩蛋介绍给大家(⊙0⊙)。

下面将使用简化的代码来介绍,主要关注jQuery的实现思想~>_<~

相较于第一篇(与第二、三篇无相关性),代码更新了:26~40

本章主要通过isFunction、isWindow、isNumberic三个的工具方法来学习类型检测和工具方法的定义。

 1 (function(window, undefined){
 2
 3     function jQuery(sel){
 4         return new jQuery.prototype.init(sel);
 5     }
 6
 7     jQuery.prototype = {
 8         constructor: jQuery,
 9         init: function(sel){
10             if(typeof sel === ‘string‘){
11                 var that = this;
12                 var nodeList = document.querySelectorAll(sel);
13                 Array.prototype.forEach.call(nodeList, function(val, i){
14                     that[i] = val;
15                 })
16                 this.selector = sel;
17                 this.length = nodeList.length;
18             }
19         }
20     }
21
22     jQuery.prototype.init.prototype = jQuery.prototype;
23
24     window.$ = jQuery;
25
26     jQuery.isFunction = function(obj) {
27         return typeof obj === ‘function‘;
28     }
29
30     //window.window 有点意思
31     jQuery.isWindow = function(obj) {
32         return obj && obj === obj.window;
33     }
34
35     jQuery.isNumberic = function(obj) {
36         //return typeof obj === ‘number‘;
37         //return Object.prototype.toString.call(obj) === ‘[object Number]‘; //发现情况一模一样
38         //return !isNaN(obj) && isFinite(obj); //漏了null
39         return !isNaN(parseFloat(obj)) && isFinite(obj);
40     }
41
42 })(window);

--------------------------

类型检测属于工具方法里的一种。可以看出,工具方法是直接绑定在jQuery对象下的。

isFunction的方法实现起来非常简单,内部使用typeof检测一下就ok了o(≧v≦)o~~

jQuery.isFunction = function(){
    return typeof obj === ‘function‘;
}

//外部调用
$.isFunction(fun1);

 --------------------------

isWindow实现起来需要点技巧:全局变量都绑定在window下,window本身也在全局变量中,所以可以通过window访问window。

//(⊙0⊙) 有点意思
window.window.window

使用这个小技巧,可以写出代码:

jQuery.isWindow = function(obj) {
    return obj && obj === obj.window;
    //觉得可以简化成
    //return window === obj;
}

--------------------------

最后来个稍复杂点的isNumberic(isNumber),我们先列出所有可能的验证数据:

1, ‘1‘, ‘1cm‘, ‘cm1‘, 2e64, ‘2e64‘, NaN, Infinity, null

先试试用typeof检测一下

jQuery.isNumberic = function(obj) {
    return typeof obj === ‘number‘;
}

看完结果,怒吼一声,typeof你个垃鸡ψ(╰_╯):

突然灵机一动,可以试一下用Object.prototype.toString来检测,说干就干:

jQuery.isNumberic = function(obj) {
    return Object.prototype.toString.call(obj) === ‘[object Number]‘;
}

发现,结果一模一样(⊙0⊙)。

没办法,只能得先回到typeof。只差这四个没检测过了,分析一下,立马想到isNaN和isFinite两个函数。

‘1‘, ‘2e64‘, NaN, Infinity

假装写了代码,然后发现isNaN和isFinite两者一结合,把typeof的事情也干了。于是顺理成章地删掉typeof,得到:

【不知道这两个函数的作用,直接拉到最下面,有贴心的小例子╰( ̄▽ ̄)╮】

jQuery.isNumberic = function(obj) {
    return !isNaN(obj) && isFinite(obj);
}

运行一下,看完有点小激动,只剩下null了o(≧v≦)o~~:

分析后,是因为isFinite(null)返回true。

最后代码可修改为注释那行,jQuery源码中为未注释那行,目测效果都一样(⊙0⊙):

jQuery.isNumberic = function(obj) {
    return !isNaN(parseFloat(obj)) && isFinite(obj);
   //return obj!=null && !isNaN(obj) && isFinite(obj)
}

最后发现漏检查了undefined,测试之后发现没问题~>_<~+

--------------------------

附录

isFinite函数的功能

isNaN函数的功能:

时间: 2024-08-27 00:24:52

jQuery的XX如何实现?——4.类型检查的相关文章

TypeScript——类型检查机制

类型检查机制:TypeScript编译器在做类型检查时,所秉承的一些原则,以及表现出的一些行为. 作用:辅助开发,提高开发效率. 类型推断 :指不需要指定变量的类型(函数的返回值类型),TypeScript可以根据某些规则自行的推断出一个类型 1.基础类型推断2.最佳通用类型推断3.上下文类型推断 - 前两者都是从右往左的推断,根据值去推断, 例如 let a = 1 // a 被推断的类型是 number let a = 1 - 最佳通用类型推断 例如 let b = [1, 'a'] //

javascript函数参数、返回值类型检查

实现带参数.返回值类型声明的js函数: 类型定义:window.Str = Type.Str = Type.define('STRING', Type.isStr);var Per = Type.define('PERSON', function(p){    return p && p.type === 'person' && p.name;}); 定义函数:var addStr = Str(function(a, b){  return a + b;}, Str, St

Java中静态类型检查是如何进行的

以下内容来自维基百科,关于静态类型检查和动态类型检查的解释: 静态类型检查:基于程序的源代码来验证类型安全的过程: 动态类型检查:在程序运行期间验证类型安全的过程: Java使用静态类型检查在编译期间分析程序,确保没有类型错误.基本的思想是不要让类型错误在运行期间发生. 以下代码是一个例子,理解了他,你会更好的理解Java静态类型检查是如何工作的. 代码示例 假定我们有如下类,A和B,B继承A. class A { A me() { return this; } public void doA(

jquery把int类型转换成字符串类型的方法

jQuery中把获取的number类型数据转换成字符串类型 var val=$("#id).val(); If(typeof val=="number"){ val+=' '; }

关于C++类型检查的一点小挫折

 问题: 定义了一个float型数组Lut[],我让一个整型指针指向数组名int * Address=lut ; VS2008报错: error C2440: '=' : cannot convert from 'float [256]' to 'int * ' 疑问:貌似在我C语言中,不止一次听过数组名代表数组的首地址:为啥在C++面前就不好使了(PS C++严格类型检查or类型匹配): 详细解答时间查查资料便晓得喽!不能不说C++的严谨性:近期查到Reason后,会记录在此!

jQuery的XX如何实现?——1.框架介绍

源码链接:内附实例代码 jQuery使用许久了,但是有一些API的实现实在想不通.于是抽空看了jQuery源码,现在把学习过程中发现的一些彩蛋介绍给大家(⊙0⊙). 下面将使用简化的代码来介绍,主要关注jQuery的实现思想~>_<~ 1 //匿名立即执行函数 2 //1.防止污染全局空间 3 //2.选择性保护内部变量 4 (function(window, undefined){ 5 //第二参数undefined设置而不传的原因: 6 // 外部发生这种情况:var undefined

JAVA 7新特性——在单个catch代码块中捕获多个异常,以及用升级版的类型检查重新抛出异常

在Java 7中,catch代码块得到了升级,用以在单个catch块中处理多个异常.如果你要捕获多个异常并且它们包含相似的代码,使用这一特性将会减少代码重复度.下面用一个例子来理解. Java 7之前的版本: 1 2 3 4 5 6 7 8 9 10 catch (IOException ex) {      logger.error(ex);      throw new MyException(ex.getMessage()); catch (SQLException ex) {      

Swift类型检查与转换

继承会发生在子类和父类中,如图所示,是一系列类的继承关系类图,Person是类层次结构中的根类,Student是Person的直接子类,Worker是Person的直接子类.这个继承关系类图的具体实现代码如下: class Person { var name : String var age : Int func description() -> String { return "\(name) 年龄是: \(age)" } convenience init () { self.

jQuery的XX如何实现?——3.data与cache机制

往期回顾: jQuery的XX如何实现?——1.框架 jQuery的XX如何实现?——2.show与链式调用 -------------------------- 源码链接:内附实例代码 jQuery使用许久了,但是有一些API的实现实在想不通.于是抽空看了jQuery源码,现在把学习过程中发现的一些彩蛋介绍给大家(⊙0⊙). 下面将使用简化的代码来介绍,主要关注jQuery的实现思想~>_<~ 相较于第一篇(与第二篇无相关性),代码更新了:27~71 1 (function(window,