22 JavaScript学习:表单验证

简介: 22 JavaScript学习:表单验证

JavaScript 表单验证

JavaScript 表单验证是一种常用的前端技术,可以通过编写 JavaScript 脚本来对用户在表单中输入的数据进行验证,确保其格式和内容符合要求。下面是一个简单的示例代码,演示如何使用 JavaScript 来进行表单验证:

<!DOCTYPE html>
<html>
<head>
    <title>表单验证示例</title>
    <script>
        function validateForm() {
            var name = document.getElementById('name').value;
            var email = document.getElementById('email').value;
            
            if (name === '') {
                alert('请输入姓名');
                return false;
            }
            
            if (email === '' || !email.includes('@')) {
                alert('请输入有效的邮箱地址');
                return false;
            }
            
            // 可以添加更多的验证规则
            
            return true;
        }
    </script>
</head>
<body>
    <h2>表单验证示例</h2>
    <form onsubmit="return validateForm()">
        <label for="name">姓名:</label>
        <input type="text" id="name" name="name"><br><br>
        
        <label for="email">邮箱:</label>
        <input type="email" id="email" name="email"><br><br>
        
        <input type="submit" value="提交">
    </form>
</body>
</html>

JavaScript 表单验证是通过在前端页面中编写 JavaScript 脚本来实现的。其原理是在用户提交表单时,触发 JavaScript 函数进行对用户输入数据的验证,以确保其格式和内容符合预期。

在示例代码中,validateForm() 函数被绑定在表单的 onsubmit 事件上,这意味着当用户点击提交按钮时,该函数会被调用。在函数内部,首先获取了用户输入的姓名和邮箱信息,然后对其进行验证。

验证规则包括:

  1. 姓名不能为空。如果姓名为空,则弹出提示框显示"请输入姓名",并返回 false,阻止表单提交。
  2. 邮箱不能为空且必须包含 “@” 符号。如果邮箱为空或不包含 “@” 符号,则弹出提示框显示"请输入有效的邮箱地址",并返回 false,阻止表单提交。
  3. 可以根据需要添加更多的验证规则,比如密码长度、电话号码格式等。

如果所有的验证规则通过,则返回 true,允许表单提交。

这种前端表单验证的方式可以提高用户体验,使用户在提交表单之前即可得知输入是否符合要求,从而减少了错误提交的可能性。但需要注意,前端验证只能作为一种辅助手段,真正的数据验证应该在后端进行,以确保数据的安全性和可靠性。

JavaScript 验证输入的数字

要验证用户输入的数字,通常可以使用 JavaScript 来实现。以下是一个简单的示例代码来验证用户输入的数字:

function validateNumberInput(input) {
    // 使用isNaN函数判断输入是否为有效数字
    if (isNaN(input)) {
        return false; // 如果不是数字,则返回false
    } else {
        return true; // 如果是数字,则返回true
    }
}

在这个示例中,定义了一个名为validateNumberInput的函数,它接收一个输入作为参数,并使用JavaScript的内置函数isNaN来判断输入是否为有效的数字。如果输入是数字,则返回true;如果不是数字,则返回false

你可以将这个函数与用户输入的值进行结合,当用户输入数字后调用这个函数来验证输入。例如:

var userInput = "123"; // 这里假设用户输入是"123"
if (validateNumberInput(userInput)) {
    console.log("输入的是有效的数字");
} else {
    console.log("输入的不是有效的数字");
}

在上面的例子中,userInput被传递给validateNumberInput函数进行验证,并根据结果输出相应的信息。

HTML表单自动验证

HTML5引入了一些新的表单输入类型和属性,可以在不编写JavaScript的情况下自动验证用户输入。以下是一些常用的HTML表单自动验证功能:

  1. 必填字段验证:通过在输入框中添加required属性,可以指定该字段为必填项。如果用户尝试提交表单时必填字段为空,浏览器会自动显示验证提示信息,并阻止表单提交。
<input type="text" name="username" required>
  1. 邮箱验证:使用type="email"属性可以告诉浏览器验证输入是否符合邮箱格式要求。
<input type="email" name="email">
  1. 数字验证:通过type="number"属性可以指定输入字段为数字类型。浏览器会自动验证用户输入是否为有效的数字。
<input type="number" name="quantity">
  1. 最小值和最大值验证:使用minmax属性可以指定数字输入字段的最小值和最大值。
<input type="number" name="age" min="18" max="100">
  1. 模式匹配验证:使用pattern属性可以指定输入字段的正则表达式模式,浏览器会自动验证用户输入是否符合模式要求。
<input type="text" name="postcode" pattern="[0-9]{6}">

这些HTML表单自动验证功能可以在一定程度上简化前端验证的工作,并提供了基本的输入验证功能。然而,仍然建议在后端进行数据验证,以确保数据的安全性和可靠性。

JavaScript数据验证

好的,我将为您提供JavaScript数据验证的信息。

在JavaScript中,数据验证是确保用户输入符合预期格式、范围和规则的过程。以下是一些常见的JavaScript数据验证方法:

  1. 正则表达式验证:与后端相似,在JavaScript中也可以使用正则表达式对输入数据进行验证,以确保其符合特定的模式要求。例如,验证邮箱地址、电话号码、邮政编码等。
const emailPattern = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
if (emailPattern.test(userInput)) {
    // 邮箱地址格式正确
} else {
    // 邮箱地址格式不正确
}
  1. 范围验证:对于数字输入,可以在JavaScript中验证其是否在预期范围内,例如年龄是否在合理范围内。
const age = parseInt(userInput, 10);
if (age >= 18 && age <= 100) {
    // 年龄在合理范围内
} else {
    // 年龄不在合理范围内
}
  1. 安全验证:在JavaScript中同样需要确保输入数据不包含恶意内容,防止跨站脚本攻击等安全漏洞。可以使用DOM操作时注意避免直接插入未经处理的用户输入到HTML中,以及使用内置的API来处理用户输入,以防止恶意代码执行。
const userInput = document.getElementById('userInput').value;
// 对于DOM操作,避免直接插入未经处理的用户输入到HTML中
// 采用安全的API来操作DOM,如textContent、setAttribute等

这些方法可以帮助确保JavaScript应用程序接收到的输入数据是安全可靠的,从而提高应用程序的安全性和可靠性。

HTML 约束验证

HTML 属性、CSS 伪类选择器以及 DOM 属性和方法的 HTML 约束验证。

HTML 属性

  1. required 属性:用于指定表单元素是否为必填项。
<input type="text" name="username" required>
  1. min 和 max 属性:用于指定数值输入的最小值和最大值。
<input type="number" name="age" min="18" max="100">
  1. pattern 属性:用于指定输入字段的正则表达式模式,确保用户输入符合特定的格式要求。
<input type="text" name="email" pattern="[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}">

CSS 伪类选择器

在 CSS 中,你也可以使用伪类选择器来改变表单元素的样式,以提供视觉上的反馈或增加用户体验。

  1. :valid 和 :invalid:用于选择输入值合法或非法的表单元素。
input:valid {
  border-color: green;
}
input:invalid {
  border-color: red;
}

DOM 属性和方法

在 JavaScript 中,你可以使用 DOM 属性和方法来访问和操作 HTML 元素,以及对用户输入进行验证。

  1. HTMLInputElement.validity 属性:返回一个 ValidityState 对象,其中包含有关输入的有效性的信息。
const usernameInput = document.getElementById('username');
if (usernameInput.validity.valueMissing) {
  // 用户未输入用户名
}
  1. HTMLFormElement.checkValidity() 方法:用于验证表单元素是否有效,返回 true 或 false。
const form = document.getElementById('myForm');
if (form.checkValidity()) {
  // 表单数据有效,可以提交
} else {
  // 表单数据无效,需要用户修正
}

这些方法可以结合使用,以提供全面的 HTML 约束验证,同时改善用户体验和数据安全性。

经典验证举例

当涉及到 JavaScript 的邮箱验证、手机验证和身份证号验证时,通常会使用正则表达式来实现。以下是一些简单的示例代码:

  1. 邮箱验证:
function validateEmail(email) {
    const re = /\S+@\S+\.\S+/;
    return re.test(email);
}
// 使用示例
console.log(validateEmail('example@email.com')); // true
console.log(validateEmail('invalid-email')); // false
  1. 手机号验证:
function validatePhone(phone) {
    const re = /^1\d{10}$/;
    return re.test(phone);
}
// 使用示例
console.log(validatePhone('13800138000')); // true
console.log(validatePhone('12345678901')); // false
  1. 身份证号验证:
function validateIDCard(idCard) {
    const re = /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/;
    return re.test(idCard);
}
// 使用示例
console.log(validateIDCard('11010119900101123X')); // true
console.log(validateIDCard('1234567890123456')); // fals

请注意,以上示例代码是简单的验证逻辑,实际情况可能会更复杂,具体验证规则也可能因地区而异。最好根据具体需求和业务场景进行调整和优化。

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步

相关文章
|
3月前
|
JavaScript 前端开发 开发者
VUE 开发——Node.js学习(一)
VUE 开发——Node.js学习(一)
97 2
|
2月前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
54 5
|
2月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
34 2
|
2月前
|
存储 JavaScript 前端开发
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
57 1
|
3月前
|
JavaScript
js学习--制作猜数字
js学习--制作猜数字
47 4
js学习--制作猜数字
|
3月前
|
JavaScript
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
这篇文章介绍了如何将webpack的配置文件分离成开发环境和生产环境的配置文件,以提高打包效率。
59 1
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
|
4月前
|
算法 JavaScript 前端开发
第一个算法项目 | JS实现并查集迷宫算法Demo学习
本文是关于使用JavaScript实现并查集迷宫算法的中国象棋demo的学习记录,包括项目运行方法、知识点梳理、代码赏析以及相关CSS样式表文件的介绍。
第一个算法项目 | JS实现并查集迷宫算法Demo学习
|
4月前
|
JavaScript 前端开发 API
紧跟月影大佬的步伐,一起来学习如何写好JS(上)
该文章跟随月影老师的指导,探讨了编写优质JavaScript代码的三大原则:各司其职、组件封装与过程抽象,通过具体示例讲解了如何在实际开发中应用这些原则以提高代码质量和可维护性。
紧跟月影大佬的步伐,一起来学习如何写好JS(上)
|
3月前
|
JavaScript
js学习--制作选项卡
js学习--制作选项卡
43 4
|
3月前
|
JavaScript
js学习--商品列表商品详情
js学习--商品列表商品详情
33 2