WebEnh

.net7 mvc jquery bootstrap json 学习中 第一次学PHP,正在研究中。自学进行时... ... 我的博客 https://enhweb.github.io/ 不错的皮肤:darkgreentrip,iMetro_HD
随笔 - 1079, 文章 - 1, 评论 - 75, 阅读 - 174万
  首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

设置表单的默认值、检测表单是否变更

Posted on   WebEnh  阅读(385)  评论(0编辑  收藏  举报
复制代码
通过动态加载表单内容,要求检测加载之后有没有变更过,可以通过defaultValue或者defaultSelected、defaultChecked属性来完成


首先,加载完成后设置默认值为当前状态的值:

//设置当前值为表单默认值
function setDefault(element) {
    if (typeof (element) == "string") {
        element = document.getElementById(element);
        if (!element) { return null; }
    }
    var type = element.type;
    if (type == "checkbox" || type == "radio") {
        element.defaultChecked = element.checked;
    }
    else if (type == "hidden" || type == "password" || type == "text" || type == "textarea") {
        element.defaultValue = element.value;
    }
    else if (type == "select-one" || type == "select-multiple") {
        for (var j = 0; j < element.options.length; j++) {
            element.options[j].defaultSelected = element.options[j].selected;
        }
    }
    var childs = element.childNodes;
    for (var i = 0; i < childs.length; i++) {
        setDefault(childs[i]);
    }
}


检测代码:

//判断表单是否改变过
function formIsDirty(form) {
    if (typeof (form) == "string") {
        form = document.getElementById(form);
        if (!form) { return null;}
    }
    for (var i = 0; i < form.elements.length; i++) {
        var element = form.elements[i];
        var type = element.type;
        if (type == "checkbox" || type == "radio") {
            if (element.checked != element.defaultChecked) {
                return true;
            }
        }
        else if (type == "hidden" || type == "password" || type == "text" || type == "textarea") {
            if (element.value != element.defaultValue) {
                return true;
            }
        }
        else if (type == "select-one" || type == "select-multiple") {
            for (var j = 0; j < element.options.length; j++) {
                if (element.options[j].selected != element.options[j].defaultSelected) {
                    return true;
                }
            }
        }
    }
    return false;
}
复制代码

 

编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2016-08-03 ASP.NET MVC从视图传递多个模型到Controller
2016-08-03 学习Entity Framework 中的Code First
2016-08-03 为你的Web程序加个启动画面
2016-08-03 asp.net mvc SelectList 的selected 失效及解决方案
2016-08-03 在类库中引用WebService的注意事件
2016-08-03 Asp.net Mvc 多级控制器 路由重写 及 多级Views目录 的寻找视图的规则 (多级路由) 如:Admin/Test/Index
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

了解更多