前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Thinking--validatorjs中isIP的巧妙实现

Thinking--validatorjs中isIP的巧妙实现

作者头像
奋飛
发布2022-05-05 08:03:05
1730
发布2022-05-05 08:03:05
举报
文章被收录于专栏:Super 前端Super 前端

Thinking系列,旨在利用10分钟的时间传达一种可落地的编程思想。

isIP 是 validatorjs 中经常被使用到的验证方法,关于该验证方法具体是如何实现的?validatorjs 中又有哪些好的点可以借鉴?

方法

说明

isIP(str [, version])

check if the string is an IP (version 4 or 6)

version 作为可选项,如果不传递任何值,需要进行 v4 或 v6 的判断,任何一个通过即可。

模拟实现

编写两个冗长的正则 IPv4RegExp、IPv6RegExp

对 version 进行判断

上述方式有两个问题:

(1)IPv4RegExp、IPv6RegExp 正则的编写可能比较冗长,且兼容性、效率可能有待商榷; (2)代码整洁度不够,特别是 if...else if...else 的结构;

isIP(str [, version])

检查字符串是否为 IP(版本 4 或 6)。源码地址

代码语言:javascript
复制
export default function isIP(str, version = '') {
  version = String(version);
  if (!version) {
    return isIP(str, 4) || isIP(str, 6);
  }
  if (version === '4') {
    if (!IPv4AddressRegExp.test(str)) {
      return false;
    }
    const parts = str.split('.').sort((a, b) => a - b);
    return parts[3] <= 255;
  }
  if (version === '6') {
    return !!IPv6AddressRegExp.test(str);
  }
  return false;
}

关于 IPv4AddressRegExp 的实现:

代码语言:javascript
复制
const IPv4SegmentFormat = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';
const IPv4AddressFormat = `(${IPv4SegmentFormat}[.]){3}${IPv4SegmentFormat}`;
const IPv4AddressRegExp = new RegExp(`^${IPv4AddressFormat}$`)

version 为空的情况,v4、v6任一通过即可

代码语言:javascript
复制
if (IPv4AddressRegExp.test(str) || IPv6AddressRegExp.test(str)) 

不做特殊分支,而是依附于当前分支情况

代码语言:javascript
复制
return isIP(str, 4) || isIP(str, 6)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-05-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 模拟实现
  • isIP(str [, version])
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档