下载鸥 > 网站下载 > 开发教程 > JS/JQuery

原生js检查标题、留言不为空,手机、邮箱合规

38 2024-06-13 18:00:03

收藏
一个简单的页面验证还使用jQuery比较麻烦,而且浪费带宽。所以,鸥哥这里分享一段原生js的验证。
 

button为普通按钮时

html代码

<form id="myForm">  
    <input type="text" name="phone" placeholder="手机号码">  
    <input type="email" name="email" placeholder="邮箱地址">  
    <input type="text" name="title" placeholder="标题">  
    <textarea name="message" placeholder="留言"></textarea>  
    <button type="button" onclick="validateForm()">提交</button>  
</form>
 

js代码

function validateForm() {  
    var form = document.getElementById('myForm');  
    var phoneInput = form.elements['phone'];  
    var emailInput = form.elements['email'];  
    var titleInput = form.elements['title'];  
    var messageTextarea = form.elements['message'];  
  
    // 检查手机号码(简单示例,仅检查是否为11位数字)  
    function isValidPhone(phone) {  
        var regex = /^\d{11}$/; // 假设手机号码为11位数字  
        return regex.test(phone);  
    }  
  
    // 检查邮箱地址  
    function isValidEmail(email) {  
        var regex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; // 简单的邮箱验证正则表达式  
        return regex.test(email);  
    }  
  
    // 检查标题和留言是否为空  
    function isNotEmpty(value) {  
        return value.trim() !== '';  
    }  
  
    // 验证手机号码  
    if (!isValidPhone(phoneInput.value)) {  
        alert('手机号码格式不正确!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证邮箱地址  
    if (!isValidEmail(emailInput.value)) {  
        alert('邮箱地址格式不正确!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证标题是否为空  
    if (!isNotEmpty(titleInput.value)) {  
        alert('标题不能为空!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证留言是否为空  
    if (!isNotEmpty(messageTextarea.value)) {  
        alert('留言不能为空!');  
        return false; // 验证失败,停止后续验证  
    }  

    // 验证其他独立字段
    if(obj.count!=null)
    {
        if(obj.count.value=='')
        {
            document.getElementsByClassName("warn-count")[0].style.display = "block";
            return false;
        }
    }
  
    // 所有验证都通过,可以提交表单或执行其他操作  
    alert('表单验证通过!');  
    // 例如:form.submit(); // 如果要提交表单到服务器,取消注释这行代码  
    return true;  
}
 

button为submit时

html代码

<form id="myForm" onsubmit="return validateForm(event)">  
    <input type="text" name="phone" placeholder="手机号码">  
    <input type="email" name="email" placeholder="邮箱地址">  
    <input type="text" name="title" placeholder="标题">  
    <textarea name="message" placeholder="留言"></textarea>  
    <button type="submit">提交</button>  
</form>  
 

js代码

function validateForm() {  
    event.preventDefault();
    var form = document.getElementById('myForm');  
    var phoneInput = form.elements['phone'];  
    var emailInput = form.elements['email'];  
    var titleInput = form.elements['title'];  
    var messageTextarea = form.elements['message'];  
  
    // 检查手机号码(简单示例,仅检查是否为11位数字)  
    function isValidPhone(phone) {  
        var regex = /^\d{11}$/; // 假设手机号码为11位数字  
        return regex.test(phone);  
    }  
  
    // 检查邮箱地址  
    function isValidEmail(email) {  
        var regex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; // 简单的邮箱验证正则表达式  
        return regex.test(email);  
    }  
  
    // 检查标题和留言是否为空  
    function isNotEmpty(value) {  
        return value.trim() !== '';  
    }  
  
    // 验证手机号码  
    if (!isValidPhone(phoneInput.value)) {  
        alert('手机号码格式不正确!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证邮箱地址  
    if (!isValidEmail(emailInput.value)) {  
        alert('邮箱地址格式不正确!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证标题是否为空  
    if (!isNotEmpty(titleInput.value)) {  
        alert('标题不能为空!');  
        return false; // 验证失败,停止后续验证  
    }  
  
    // 验证留言是否为空  
    if (!isNotEmpty(messageTextarea.value)) {  
        alert('留言不能为空!');  
        return false; // 验证失败,停止后续验证  
    }  

    // 验证其他独立字段
    if(obj.count!=null)
    {
        if(obj.count.value=='')
        {
            document.getElementsByClassName("warn-count")[0].style.display = "block";
            return false;
        }
    }
  
    if (isValidPhone(phoneInput.value) &&   
        isValidEmail(emailInput.value) &&   
        isNotEmpty(titleInput.value) &&   
        isNotEmpty(messageTextarea.value)) {    
        form.submit();
    } else {  
        alert('表单验证失败,请检查输入!');  
    }  
}

虽然看着复杂,但复制粘贴就能用,还节约了jQuery的带宽和内存。

本文地址:https://xzo.com.cn/develop/js/1271.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于JS/JQuery


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐JS/JQuery开发教程
JS怎样做倒计时效果?
JS怎样做倒计时效果?

在各种盛大的节日、活动前,网站制作倒计时特效可有效给活动页引流。那么,怎样...

1 421
JavaScript过滤XSS攻击方法
JavaScript过滤XSS攻击方法

什么是XSS?XSS(Cross Site Scripting),跨站脚本攻击,是一种允许攻击者在另外一个...

1 348
JS验证手机是否11位的做法
JS验证手机是否11位的做法

在网站表单提交前,我们往往需要验证一下信息避免错误数据,那么,怎样验证手机号...

1 394
怎样点击清除ul里的全部li信息?
怎样点击清除ul里的全部li信息?

在通过jQuery做数据交互时我们可能存在这样的需求:通过点击按钮清空ul里的li...

1 473
JS获取当前时间、日期、星期并每秒更新一次
JS获取当前时间、日期、星期并每秒更新一次

很多网站上会有当前年月日、星期、时间的展示。这个展示用php做未免浪费性...

0 375
jQuery监听点击事件弹出关注二维码教程
jQuery监听点击事件弹出关注二维码教程

通过jQuery实现点击关注按钮弹出二维码是一个比较常用的功能,今天鸥哥讲讲这...

0 435
js点击追加信息到textarea
js点击追加信息到textarea

通过灵活运用js,我们可以轻松实现点击追加相关信息到textarea的功能。这个功...

0 577
js判断windows操作系统还是mac os系统
js判断windows操作系统还是mac os系统

网站日常访客主要是windows和mac os两种操作系统,如果网站提供资源下载,则需...

0 1726
推荐插件
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 236
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 490
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

0 622
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 351
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1189
帝国cms百度文字识别ocr接口对接插件
帝国cms百度文字识别ocr接口对接插件

许多网站会做一些小功能小插件给客户使用以增强用户黏性,比如图片转文字,这种...

0 408
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 317
帝国cms自动生成文章新闻目录插件下载
帝国cms自动生成文章新闻目录插件下载

用户体验是我们的需求,百度蜘蛛的认可更是我们的需求。毕竟,没有收录排名,何来...

0 1026
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入