/*

  • 新版的页面控件值验证

  • @element 要验证的范围对象

  • @isValiMust 是否需要验证必填(临时保存的时候就不需要验证必填)

  • @isByName 是否依赖name寻找控件

  • @return 验证结果字符串(空为验证通过,非空表示验证不通过,返回的警告信息)

    */

    function ValidatePageControlsNew(element, isValiMust, isByName) {

    if (typeof isValiMust === 'undefined') {

    isValiMust = true;

    }

    if (typeof isByName === 'undefined') {

    isByName = false;

    }

    var warn = "";

    var isMust = undefined;

    var $label = null;

    var target;

    $(element).find('input,select,textarea').each(function (r) {

    if (isByName) {//依赖name寻找控件

    target = $(this).attr('name');

    } else {

    target = $(this).attr('id');

    }

    if (target != undefined) {

    //判断是否是必填

    if (isValiMust) {

    isMust = $(this).attr("isMust");//不需要验证的属性

    if (isMust) {

    var value = $(this).val();

    if (value == '') {

    warn = $(this).attr("placeholder");

    return false;

    }

    }

    }

         //判断格式
    var format = $(this).attr("fromat");
    var fromatwarning = $(this).attr("fromatwarning");
    var value = $(this).val();
    if (format != undefined && value != "") {//值不能为空,为空就不需要验证
    switch (format) {
    case "PositiveInt"://正整数 验证自己加 验证什么自己可以提前写好条用OK了
    if (!isPositiveInteger(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "NonnInt"://非负整数(包含0)
    if (!isNumber(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "Tel"://电话(座机或手机)
    if (!checkTel(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "Mobile"://手机
    if (!isMobile(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "Percentage"://百分比
    if (!isPosIntegerBetween100(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "Money"://金额(允许两位小数)
    if (!isDecimalMoney(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "ZipCode"://邮编
    if (!isZipCode(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    case "IDCard"://18位身份证
    if (!checkCard(value)) {
    warn = fromatwarning;
    return false;
    }
    break;
    default:
    break
    }
    } }

    });

    return warn;

    }

var warnText = ValidatePageControlsNew($("#form"), true, true);//几个参数 自己看方法有介绍 反回结果为空的话 说明验证非空通过

input type="text" name="ZSBZ" id="ZSBZ" class="form-control" ismust="true" fromat="Money" fromatwarning="请输入正确的住宿费格式" placeholder="请输入住宿费安排标准" value="" //placeholder 为空返回的内容 ismust 是否进行为空验证 fromat="Money" 这个就是对数据格式的验证了 看上面的方法 有说明 fromatwarning 数据格式验证不通过的返回值

很方便简洁的from 表单验证

from 验证的更多相关文章

  1. 【探索】无形验证码 —— PoW 算力验证

    先来思考一个问题:如何写一个能消耗对方时间的程序? 消耗时间还不简单,休眠一下就可以了: Sleep(1000) 这确实消耗了时间,但并没有消耗 CPU.如果对方开了变速齿轮,这瞬间就能完成. 不过要 ...

  2. C# 中参数验证方式的演变

    一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限 ...

  3. Yii1.1的验证规则

    在Yii1.1的数据验证是由CValidator完成,在CValidator中提供了各种基本的验证规则 <?php public static $builtInValidators=array( ...

  4. 【WCF】使用“用户名/密码”验证的合理方法

    我不敢说俺的方法是最佳方案,反正这世界上很多东西都是变动的,正像老子所说的——“反(返)者,道之动”.以往看到有些文章中说,为每个客户端安装证书嫌麻烦,就直接采用把用户名和密码塞在SOAP头中发送,然 ...

  5. PHP验证用户登录例子-学习笔记

    1.基本流程: 2.UML类图: 3.PHP代码: 3.1 index.php <?php /** * Created by PhpStorm. * User: andy * Date: 16- ...

  6. 客户端的验证插件validator

    简单,智能,令人愉悦的表单验证~~~ 官方文档:http://www.niceue.com/validator/ <!DOCTYPE html> <html> <head ...

  7. ASP.NET MVC5+EF6+EasyUI 后台管理系统(66)-MVC WebApi 用户验证 (2)

    系列目录 前言: 回顾上一节,我们利用webapi简单的登录并进行了同域访问与跨域访问来获得Token,您可以跳转到上一节下载代码来一起动手. 继续上一篇的文章,我们接下来演示利用拿到的Token来访 ...

  8. ASP.NET MVC5+EF6+EasyUI 后台管理系统(65)-MVC WebApi 用户验证 (1)

    系列目录 前言: WebAPI主要开放数据给手机APP,其他需要得知数据的系统,或者软件应用,所以移动端与系统的数据源往往是相通的. Web 用户的身份验证,及页面操作权限验证是B/S系统的基础功能, ...

  9. 再谈C#采集,一个绕过高强度安全验证的采集方案?方案很Low,慎入

    说起采集,其实我是个外行,以前拔过阿里巴巴的客户数据,在我博客的文章:C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子) 中,介绍过采集用的工具,其实很Low的,分析 ...

  10. jQuery学习之路(8)- 表单验证插件-Validation

    ▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...

随机推荐

  1. Extjs 分页多选的实现

    Extjs 版本 6.X 单页面的多选,没有任何问题. 直接使用 Grid的配置项进行绑定即可获取: xtype: 'grid', bind: { selection: '{checkedRecord ...

  2. invocationCount和invocationTimeOut

    这篇我们来学习下@Test中另外两个属性invocationCount和invocationTimeOut,前面我介绍了timOut这个属性,知道是超时监控的功能.同样,本篇两个属性和这个差不多,只不 ...

  3. python列表解析进阶

    如果要获得一个(元素为整数的)列表里面的偶数,很容易想到列表解析: [i for i in nums if i%2==0] 但是如果要使列表的长度不变,让奇数用0来填充,可能你会直接写: [i for ...

  4. Tomcat 环境搭建

    最近在工作之余,看到了一些 Tomcat 的基础资料,感觉蛮好.同时也回忆起自己刚毕业要参加工作那会对 Tomcat 也是各种资料各种查,实属不易.为此,针对最近整理的一些基础,把 Tomcat 基本 ...

  5. 运行UART的程序

    1 捎程序的时候,注意,捎入的是norflash,此时的按钮应该在norFlash.2 当捎入成功的时候,开始运行程序时,应该把按钮按回nandflash,因为程序的启动就是在nandflash,他把 ...

  6. C#第一个windows窗体应用程序

    Form1.cs using System; …… namespace self_1_1{ public partial class Form1 : Form { public Form1() { I ...

  7. jmeter-00 JMeter 运行过程

    一.GUI mode 图形化界面运行 to run JMeter, run the jmeter.bat (for Windows) or jmeter (for Unix) file. These ...

  8. [java]BoneCP 参数详解

    BoneCP 参数详解: ======================================== 一.BoneCP配置文件格式(bonecp-config.xml):  xml versio ...

  9. centos7&redhat 之 firewalld 详细介绍配置

    firewalld和iptables的关系 firewalld自身并不具备防火墙的功能,而是和iptables一样需要通过内核的netfilter来实现,也就是说firewalld和iptables一 ...

  10. iptables详解(13):iptables动作总结之二

    概述 阅读这篇文章需要站在前文的基础上,如果你在阅读时遇到障碍,请参考之前的文章. 前文中,我们已经了解了如下动作 ACCEPT.DROP.REJECT.LOG 今天,我们来认识几个新动作,它们是: ...