校验类型三种实现

Posted bonly-ge

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了校验类型三种实现相关的知识,希望对你有一定的参考价值。

常用的校验类型方法和特点

  1. typeof 不能校验 对象 数组 null
  2. instanceof 谁是谁的实例
  3. Object.prototype.toString.call 不能判断实例
  4. constructor 判断当前是谁的构造函数

简单实现checkType

function checkType(type,value){
    return Object.prototype.toString.call(value) === `[object ${type}]`
}
// 使用
let res = checkType('String','123');

使用高阶函数实现

这个checkType函数返回的函数和传入的type组成了一个闭包函数,是传入的type在另一个函数中使用

function checkType(type){
    return function(value){
        return Object.prototype.toString.call(value)===`[object ${type}]`
    }
}
// 使用
let isString = checkType('String');
let isNumber = checkType('Number');
console.log(isString('123'));

柯里化实现

  • 如果一下想不到怎么实现柯里化函数的额写法,就考虑能不能分步骤传递参数
  • 提前把部分参数传递进去,返回一个新的函数,等待参数够达到执行条件的时候在执行
// 验证函数
function checkType(type,value){
    return Object.prototype.toString.call(value) === `[object ${type}]`;
}

// 通用柯里化函数
function curring(fn,arr =[]){
    let len = fn.length; // 代表fn需要传入参数的个数
    return function(...args){
        arr = [...arr, ...args];
        if(arr.length < len ){
            // 传入的参数达不到执行条件,递归继续接受参数
            return curring(fn,arr);
        }else{
            return fn(...arr);
        }
    }
}

// 生成验证函数
let util = {};
let types = ['String', 'Number', 'Boolean', 'Null', 'Undefined'];
types.forEach(type => {
    util[`is${type}`] = curring(checkType)(type);
})
console.log(util.isString('hello'))

柯里化概念

  • 从函数结构上来看是函数返回函数,也是高阶函数;
  • 从作用上来说是把接受多个参数变成接受单一参数;
  • 从意义上来说是把核心功能提出一个更细小的函数;
  • 从执行的过程来看是把函数参数收集起来,等待执行时机到了在执行,也就是惰性求值。

闭包概念

  • 当前这个函数可以不在当前作用域(声明时)下执行

以上是关于校验类型三种实现的主要内容,如果未能解决你的问题,请参考以下文章

eslint常用三种校验语句

StringUtils.isBlank()检验String 类型的变量是否为空

Unity中Shader的三种基本类型

通过后缀名和MIME-TYPE检查实现文件类型校验

Android App 安全的HTTPS 通信

Spring AOP 应用:三种配置及实现方式