表单验证最重要的是验证规则中的自定义验证,即rules,返回的消息都在messages中.
下面demo我以数字、邮箱、时间举例说明:
HTML:
<form action="?" id="requrest-form"> <!-- 数字验证 --> <input type="number" name="number" required title="数字为必填项"> <!-- 邮箱验证 --> <input type="email" name="email" required title="邮箱为必填项"> <!-- 时间验证 --> <input type="text" name="time" required title="创建时间为必填项"/> <span data-for='time' class='k-invalid-msg'></span> </form>
注意:
- 其中required为必填验证,title为默认的提示消息,即必填验证消息。也可以使用data-required-msg
- 验证提示消息模板,也可以自己重写,data-for对应的是相应的name
<span data-for='time' class='k-invalid-msg'></span>
JavaScript:
var validator = $("#requrest-form").kendoValidator({ rules:{ number:function(input){ if (input.is("[name=number]")) { var min = 10, max = 100 var val = input.val(); return val <= max && val > min; } return true }, time:function(input){ if(input.is("[name=time]")){ return input.val() == "2018-05-20" } return true } }, messages:{ number:'请输入10-100之间的数字', time:'请选择2018-05-20这一天', }, validate: function(e) { console.log("valid---" + e.valid); } }).data("kendoValidator"); $(".fa-save").click(function(){ if (validator.validate()) { alert("验证成功"); } })
效果图:
验证样式,默认不是这样的,样式是我自己调的,可以参考一下
.k-invalid{ border-color:red !important; } .k-widget.k-tooltip-validation{ left: 0; margin: 0; position: absolute; margin-top: 5px; text-align: left; font-size: 12px; box-sizing: border-box !important; top: 35px; /* input的height */ width: 240px; /* input的width */ }
来自:https://www.cnblogs.com/zsj-02-14/p/9328712.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统