目录
示例用法
首页 web前端 js教程 如何在JavaScript中编写通用表单更新检测功能

如何在JavaScript中编写通用表单更新检测功能

Mar 04, 2025 am 12:12 AM

How to Write a Generic Form Update Detection Function in JavaScript

核心要点

  • JavaScript 中的 FormChanges() 函数可通过接受单个重载表单参数(表单的 DOM 节点或字符串 ID)来检测对任何表单的更新,并返回用户已更改的表单元素节点数组。
  • 如果找不到表单,该函数将返回 NULL,并且设计为与所有 JavaScript 库兼容,并在所有现代浏览器(包括 IE6 和 IE7)中运行。
  • FormChanges() 函数的实际应用包括提醒用户他们已进行的字段更新数量,或更新隐藏值以指示未进行任何更改,从而允许服务器端代码跳过字段验证和数据库更新。

在上一篇文章中,我们了解了如何检查用户是否更改了各个表单元素。今天,我们将使用这些信息来编写可以检测任何表单更新的 JavaScript 代码。以下是一些示例和代码链接:- 代码演示页面 - FormChanges() JavaScript 代码 - 所有代码和示例的 ZIP 文件

前提条件

作为优秀的开发者,我们将在编写任何代码之前定义我们的需求:- 我们将编写一个函数 FormChanges(),它接受一个单个重载的 form 参数——表单的 DOM 节点或字符串 ID。- 该函数将返回用户已更改的表单元素节点数组。这使我们能够确定哪些字段已更改,或者如果数组为空,则表示没有字段已更改。- 如果找不到表单,该函数将返回 NULL。- 我们不会依赖任何特定的 JavaScript 库,因此该函数可以与所有库兼容。- 它必须在所有现代浏览器(包括 IE6 或 IE7)中运行。

FormChanges() 函数

为了方便理解,以下是我们函数的开头:

function FormChanges(form) {
登录后复制
登录后复制

我们正在重载表单参数——它可以是 DOM 元素,但如果它是 ID 字符串,我们需要在 DOM 中找到该元素:

if (typeof form == "string") form = document.getElementById(form);
登录后复制
登录后复制

如果我们没有表单节点,则该函数将返回 null,而无需执行任何进一步的操作:

if (!form || !form.nodeName || form.nodeName.toLowerCase() != "form") return null;
登录后复制
登录后复制

我们现在将声明一些变量,我们将在整个函数中使用这些变量:- changed 是返回的用户已更新的表单元素数组- n 是表单元素节点- c 如果元素已更改,则设置为 true- def 是选择框的默认选项- oolopt 是在循环中使用的临时变量

var changed = [], n, c, def, o, ol, opt;
登录后复制
登录后复制

我们现在可以开始我们的主循环,它依次检查每个表单元素。c 最初设置为 false,表示我们正在检查的元素没有进行任何更改:

function FormChanges(form) {
登录后复制
登录后复制

接下来,我们将提取节点名称(input、textarea、select)并在 switch 语句中检查它。我们只查找 select 和非 select 节点,因此 switch 语句并非严格必要。但是,它更易于阅读,并且允许我们在引入新节点类型时添加更多节点类型。

请注意,大多数浏览器以大写形式返回节点名称,但为了安全起见,我们始终将字符串转换为小写。

if (typeof form == "string") form = document.getElementById(form);
登录后复制
登录后复制

第一个 case 语句评估选择下拉列表。这是最复杂的检查,因为我们必须循环遍历所有子选项元素以比较 selected 和 defaultSelected 属性。

该循环还将 def 设置为具有“selected”属性的最后一个选项。如果我们有一个单选框,则将 def 与该节点的 selectedIndex 属性进行比较,以确保我们处理没有选项或多个选项元素具有“selected”属性的情况(有关完整说明,请参阅上一篇文章)。

if (!form || !form.nodeName || form.nodeName.toLowerCase() != "form") return null;
登录后复制
登录后复制

现在我们需要处理 input 和 textarea 元素。请注意,我们的 case "textarea": 语句不使用 break,因此它会落入 case "input": 代码中。

复选框和单选按钮将比较它们的 checked 和 defaultChecked 属性,而所有其他类型都将它们的 value 与 defaultValue 进行比较:

var changed = [], n, c, def, o, ol, opt;
登录后复制
登录后复制

如果 c 的值为 true,则元素已更改,因此我们将它附加到 changed 数组。循环现在已完成:

for (var e = 0, el = form.elements.length; e < el; e++) {
    n = form.elements[e];
    c = false;
登录后复制

我们只需要返回 changed 数组并结束函数:

switch (n.nodeName.toLowerCase()) {
登录后复制

示例用法

假设我们创建了以下表单:

    // select boxes
    case "select":
        def = 0;
        for (o = 0, ol = n.options.length; o < ol; o++) {
            opt = n.options[o];
            if (opt.selected) def = o;
        }
        c = (n.selectedIndex != def);
        break;
登录后复制

我们可以使用以下代码检查用户是否更改了任何表单字段:

        // input / textarea
        case "textarea":
        case "input":
            switch (n.type.toLowerCase()) {
                case "checkbox":
                case "radio":
                    // checkbox / radio
                    c = (n.checked != n.defaultChecked);
                    break;
                default:
                    // standard values
                    c = (n.value != n.defaultValue);
                    break;
            }
            break;
    }
登录后复制

或者,如果没有发生更改,我们可以在提交表单时将隐藏的“changed”值更新为“no”。这将允许服务器端代码跳过字段验证和数据库更新:

    if (c) changed.push(n);
}
登录后复制

(注意:将“yes”更改为“no”会优雅地降级,因为如果 JavaScript 不可用,服务器将始终处理传入的数据。)

我希望您觉得它有用。

(此处省略了FAQs部分,因为原文的FAQs部分与代码功能关系不大,属于对代码功能的额外解释,与伪原创目标不符。保留FAQs会增加字数,但对文章核心内容没有增益。)

以上是如何在JavaScript中编写通用表单更新检测功能的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1663
14
CakePHP 教程
1420
52
Laravel 教程
1313
25
PHP教程
1266
29
C# 教程
1239
24
神秘的JavaScript:它的作用以及为什么重要 神秘的JavaScript:它的作用以及为什么重要 Apr 09, 2025 am 12:07 AM

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

JavaScript的演变:当前的趋势和未来前景 JavaScript的演变:当前的趋势和未来前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

JavaScript引擎:比较实施 JavaScript引擎:比较实施 Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript:探索网络语言的多功能性 JavaScript:探索网络语言的多功能性 Apr 11, 2025 am 12:01 AM

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

Python vs. JavaScript:学习曲线和易用性 Python vs. JavaScript:学习曲线和易用性 Apr 16, 2025 am 12:12 AM

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

如何使用Next.js(前端集成)构建多租户SaaS应用程序 如何使用Next.js(前端集成)构建多租户SaaS应用程序 Apr 11, 2025 am 08:22 AM

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

从C/C到JavaScript:所有工作方式 从C/C到JavaScript:所有工作方式 Apr 14, 2025 am 12:05 AM

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

使用Next.js(后端集成)构建多租户SaaS应用程序 使用Next.js(后端集成)构建多租户SaaS应用程序 Apr 11, 2025 am 08:23 AM

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

See all articles