首页IT科技adf校验(Ajvformat校验使用示例分析)

adf校验(Ajvformat校验使用示例分析)

时间2025-07-10 16:37:26分类IT科技浏览6499
导读:初始化项目demo npm init...

初始化项目demo

npm init -y

安装 Ajv 版本 7

npm install ajv

安装ajv-formats插件

// ESM/TypeScript import import Ajv from "ajv" import addFormats from "ajv-formats" // Node.js require: const Ajv = require("ajv") const addFormats = require("ajv-formats") const ajv = new Ajv() addFormats(ajv)

运行分解

新建index.js文件

导入ajv和对应的format插件库 定义对应的schema结构 调用ajv.compile()方法                ,对schema进行编译                    ,返回一个待执行的校验函数 执行回调函数        ,并将我们需要判断的data            ,当做参数传递 判断返回的结果
const Ajv = require("ajv") const addFormats = require("ajv-formats") const ajv = new Ajv() addFormats(ajv) const schema = { type: "string", format: email, minLength: 1, maxLength: 255, pattern: /^[a-zA-Z]/ }; const validate = ajv.compile(schema) const data = string const valid = validate(data) console.log(valid) if (!valid) console.log(validate.errors)

打开控制台                    ,运行node index.js             。

分析

在这里我们就可以利用vscode自带的调试功能           ,进行代码分析了                        。首先        ,我在19行打了断点                     ,这样我们就可以观察到函数的参数和调用情况了       。不会调试的同学可以看看这篇文章 新手向:前端程序员必学基本技能——调试JS代码 调试之后              ,就可以看到编译之后的回调函数了         。如下代码

(function anonymous(self, scope) { const schema11 = scope.schema[6]; const formats0 = scope.formats[0]; const func2 = scope.func[1]; const pattern0 = scope.pattern[0]; return function validate10(data, {instancePath = "", parentData, parentDataProperty, rootData = data} = {}) { let vErrors = null; let errors = 0; if (errors === 0) { if (errors === 0) { if (typeof data === "string") { if (func2(data) > 255) { validate10.errors = [{ instancePath, schemaPath: "#/maxLength", keyword: "maxLength", params: { limit: 255 }, message: "must NOT have more than 255 characters" }]; return false; } else { if (func2(data) < 1) { validate10.errors = [{ instancePath, schemaPath: "#/minLength", keyword: "minLength", params: { limit: 1 }, message: "must NOT have fewer than 1 characters" }]; return false; } else { if (!pattern0.test(data)) { validate10.errors = [{ instancePath, schemaPath: "#/pattern", keyword: "pattern", params: { pattern: "/^[a-zA-Z]/" }, message: "must match pattern "" + "/^[a-zA-Z]/" + """ }]; return false; } else { if (!formats0.test(data)) { validate10.errors = [{ instancePath, schemaPath: "#/format", keyword: "format", params: { format: "email" }, message: "must match format "" + "email" + """ }]; return false; } } } } } else { validate10.errors = [{ instancePath, schemaPath: "#/type", keyword: "type", params: { type: "string" }, message: "must be string" }]; return false; } } } validate10.errors = vErrors; return errors === 0; }; });

通过以上文件我们可以看到    ,ajv对我们定义好的shcma进行编译                      ,编译之后生成了一个回调函数                       。在回调函数中对                 ,定义好的规则进行判断处理           。

首先是对type类型的判断处理,然后是字符串类型的最大长度             、最小长度和正则的校验                   ,最后是对format的规则校验      。

如果                    ,其中的一项不满足规则时    ,直接会走到errors里边                ,把错误信息进行处理输出                      。

总结

了解Ajv的的判断逻辑                    ,先进行schema的定义        ,然后compile进行schema的编译                        、生成回调函数            ,最后输入data数据进行校验               。

在我们定义好schema之后                    ,在string类型中           ,他会按照先type       、字符串最大长度         、最小长度                       、正则判断和format的顺序进行        ,data的校验   。

以上就是Ajv format校验使用示例分析的详细内容                     ,更多关于Ajv format校验的资料请关注本站其它相关文章!

声明:本站所有文章              ,如无特殊说明或标注    ,均为本站原创发布                     。任何个人或组织                      ,在未征得本站同意时                 ,禁止复制           、盗用      、采集                      、发布本站内容到任何网站               、书籍等各类媒体平台                   。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
php中实现文件上传的函数是什么(关于phpcms上传错误404的解决办法) 网站关键词收录查询(全面解读关键词全网采集:打造网页优化的利器)