docs/reference/predicate/isFunction.md
Checks if a value is a function.
const result = isFunction(value);
isFunction(value)Use isFunction when you want to check if a value is a function. Can detect all types of functions including regular functions, async functions, generator functions, and constructor functions.
import { isFunction } from 'es-toolkit/predicate';
// Regular functions
console.log(isFunction(function () {})); // true
console.log(isFunction(() => {})); // true
console.log(isFunction(Array.prototype.slice)); // true
// Async functions
console.log(isFunction(async function () {})); // true
console.log(isFunction(async () => {})); // true
// Generator functions
console.log(isFunction(function* () {})); // true
// Constructors
console.log(isFunction(Array)); // true
console.log(isFunction(Date)); // true
console.log(isFunction(RegExp)); // true
console.log(isFunction(Promise)); // true
Also detects built-in JavaScript functions and classes:
// Built-in constructors
console.log(isFunction(Object)); // true
console.log(isFunction(String)); // true
console.log(isFunction(Number)); // true
console.log(isFunction(Boolean)); // true
// Typed array constructors
console.log(isFunction(Int8Array)); // true
console.log(isFunction(Uint8Array)); // true
console.log(isFunction(Float32Array)); // true
// Proxy and Reflect
console.log(isFunction(Proxy)); // true
console.log(isFunction(Reflect.get)); // true
Distinguishes from non-function values:
// Non-functions
console.log(isFunction({})); // false
console.log(isFunction([])); // false
console.log(isFunction('text')); // false
console.log(isFunction(42)); // false
console.log(isFunction(null)); // false
console.log(isFunction(undefined)); // false
// Function-like but not functions
console.log(isFunction({ call: function () {} })); // false
Useful for callback function validation or dynamic function invocation:
// Callback function validation
function processData(data: any[], callback?: unknown) {
const result = data.map(item => item * 2);
if (isFunction(callback)) {
// Can safely call callback since it's confirmed to be a function
callback(result);
}
return result;
}
// Dynamic function execution
function executeIfFunction(fn: unknown, ...args: any[]) {
if (isFunction(fn)) {
return fn(...args);
}
console.log('Given value is not a function');
return null;
}
// Checking functions in method chaining
const utils = {
data: [1, 2, 3],
process(fn: unknown) {
if (isFunction(fn)) {
this.data = this.data.map(fn);
}
return this;
},
};
value (unknown): The value to check if it's a function.(value is (...args: any[]) => any): Returns true if the value is a function, false otherwise.