npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

nifty-util

v1.2.6

Published

JavaScript实用功能

Downloads

25

Readme

nifty-util

nifty-util是一个实用的JavaScript工具库。

安装

从GitHub上下载最新的nifty-util,或使用npm安装:

npm install nifty-util

如何使用

import util from 'nifty-util'
// or
import { isEqual } from 'nifty-util'

目录

isEqual
isYummy

getScrollOffset
getViewportSize
queryToObject

date

set
get

deepClone
find
findIndex
flatArray
removeDuplicate

getType
isArray
isBoolean
isFunction
isNull
isNumber
isObject
isString
isSymbol
isUndefined

判断两个值是否绝对相等,数组/对象只比较其属性值是否绝对相等

Arguments

val1: 任意值

val2: 任意值

Returns

(boolean): 若两个值绝对相等返回true,否则返回false.

Example

const result = isEqual(1, '1')
console.log(result)
// => false

判断值是否合法

Arguments

value: 任意值

Returns

(boolean): 若值不为undefined、null、false、空字符串、空数组、空对象返回true,否则返回false.

Example

const result = isYummy({})
console.log(result)
// => false

返回滚动条滚动距离

Arguments

Returns

({ x: number, y: number }): x为横坐标滚动距离,y为纵坐标滚动距离.

Example

const result = getScrollOffset()
console.log(result)
// => { x: 0, y: 100 }

返回浏览器视口尺寸

Arguments

Returns

({ width: number, height: number }): width为视口宽度,height为视口高度.

Example

const result = getViewportSize()
console.log(result)
// => { width: 1920, height: 1080 }

将 url 参数解析为 JS 对象

Arguments

search: url参数

Returns

(Object): 一个新的对象.

Example

const objUrl = new URL('http://github.com?name=leslie&gender=male')
const result = queryToObject(objUrl.search)
console.log(result)
// => { name: 'leslie', gender: 'male' }

返回日期的详细信息

Arguments

value: 字符串日期/日期对象,不传则为当前时间.

Returns

| 属性 | 说明 | 类型 | | :---- | :---- | :---- | | year | 年份 | number | | month | 当前月份(0-11) | number | | day | 周几 | number | | date | 日 | number | | hours | 时 | number | | minutes | 分 | number | | seconds | 秒 | number | | milliseconds | 毫秒 | number | | time | 自 1970 年 1 月 1 日 00:00:00 UTC 到当前时间的毫秒数 | number | | normalMonth | 当前月份(1-12) | number | | am00Time | 0点 | number | | pm24Time | 24点 | number |

Example

const result = date()
console.log(result)
// => 
{ 
  am00Time: 1677081600000, 
  date: 23, 
  day: 4, 
  hours: 10, 
  milliseconds: 680, 
  minutes: 49, 
  month: 1, 
  normalMonth: 2, 
  pm24Time: 1677167999999 
  seconds: 36, 
  time: 1677120576680, 
  year: 2023 
}

设置对象路径处的值

Arguments

object: 要修改的对象 path: 要设置的属性的路径 value: 要设置的值

Returns

(Object): 返回的对象.

Example

const obj = {}
const result = set(obj, 'a.b', 1)
console.log(result)
// => { a: { b: 1 } }

获取对象路径处的值

Arguments

object: 要查询的对象 path: 要获取的属性的路径 defaultValue: 为未定义的解析值返回的值

Returns

(*): 返回解析值.

Example

const obj = {a: {b: 1}}
const result = set(obj, 'a.b')
console.log(result)
// => 1

深拷贝

Arguments

value: 任意值

Returns

(Object): 返回新的对象.

Example

const obj = {name: 'leslie', list: ['fruit']}
const result = deepClone(obj)
console.log(result)
// => {name: 'leslie', list: ['fruit']}

查找包含目标值的元素.

Arguments

collection: 数组 predicate: 目标值

Returns

(*): 返回包含目标值的元素,否则返回 undefined.

Example

const list = [{gender: 'male', name: 'leslie'}, { gender: 'female', name: 'lily' }]
const result1 = find(list, ['gender', 'male'])
console.log(result1)
// => {gender: 'male'}

const result2 = find(list, {gender: 'male'})
console.log(result2)
// => {gender: 'male'}

const result3 = find(list, 'male')
console.log(result3)
// => {gender: 'male'}

查找包含目标值元素的下标.

Arguments

collection: 数组 predicate: 目标值

Returns

(number): 返回匹配元素的下标,否则返回-1.

Example

const list = [{gender: 'male', name: 'leslie'}, { gender: 'female', name: 'lily' }]
const result1 = find(list, ['gender', 'male'])
console.log(result1)
// => 0

const result2 = find(list, {gender: 'male'})
console.log(result2)
// => 0

const result3 = find(list, 'male')
console.log(result3)
// => 0

数组拍平.

Arguments

value: 数组

Returns

(Array): 返回一个新的一维数组.

Example

const list = [1, [2, [3, [4]]]]
const result = flatArray(list)
console.log(result)
// => [1, 2, 3, 4]

数组去重.

Arguments

value: 数组

Returns

(Array): 返回一个新的数组.

Example

const list = [1, 1, {num: 2}, {num: 2}]
const result = removeDuplicate(list)
console.log(result)
// => [1, {num: 2}]

返回值的数据类型.

Arguments

value: 任意值.

Returns

(string): 返回boolean | NaN | number | string | array | function | object | null | undefined | symbol.

Example

const value = 1
const result = getType(value)
console.log(result)
// => number

判断是否为数组.

Arguments

value: 任意值.

Returns

(boolean): 若为数组返回true,否则返回false.

Example

const value = []
const result = isArray(value)
console.log(true)
// => true

判读是否为布尔值.

Arguments

value: 任意值.

Returns

(boolean): 若为布尔值返回true,否则返回false.

Example

const value = false
const result = isBoolean(value)
console.log(true)
// => true

判断是否为函数.

Arguments

value: 任意值.

Returns

(boolean): 若为函数返回true,否则返回false.

Example

const value = function() {}
const result = isFunction(value)
console.log(true)
// => true

判断是否为null.

Arguments

value: 任意值.

Returns

(boolean): 若为null返回true,否则返回false.

Example

const value = null
const result = isNull(value)
console.log(true)
// => true

判读是否为数值.

Arguments

value: 任意值.

Returns

(boolean): 若为数值返回true,否则返回false.

Example

const value = 1
const result = isNumber(value)
console.log(true)
// => true

判断是否为对象.

Arguments

value: 任意值.

Returns

(boolean): 若为对象返回true,否则返回false.

Example

const value = {}
const result = isObject(value)
console.log(true)
// => true

判读是否为字符串.

Arguments

value: 任意值.

Returns

(boolean): 若为字符串返回true,否则返回false.

Example

const value = ''
const result = isString(value)
console.log(true)
// => true

判断是否为symbol.

Arguments

value: 任意值.

Returns

(boolean): 若为symbol返回true,否则返回false.

Example

const value = Symbol('name')
const result = isSymbol(value)
console.log(true)
// => true

判断是否为undefined.

Arguments

value: 任意值.

Returns

(boolean): 若为symbol返回true,否则返回false.

Example

const value = void 0
const result = isUndefined(value)
console.log(true)
// => true