【分享】 纯 js 表单控件 —— 让 “增改查” 更轻松!

简介:   我们在做增删改查的时候,必可避免的要做表单,那么表单是怎么弄出来的呢?拖拽控件、手写、js创建还是第三方控件(包括js版)? 以前用服务器控件写了一套表单控件,用起来感觉也挺方便的,只是效率太低,太占用服务器的资源。

  我们在做增删改查的时候,必可避免的要做表单,那么表单是怎么弄出来的呢?拖拽控件、手写、js创建还是第三方控件(包括js版)? 以前用服务器控件写了一套表单控件,用起来感觉也挺方便的,只是效率太低,太占用服务器的资源。想了好久也没想到如何提高效率,最后改成了纯js版的。

  js属于初学,代码还很简陋,大家见笑了。现在是越学习js,越是感到js的强大!

 

需求、目的:
1、 在前台网页,使用js自动创建表单
2、 可以控制表单里的控件类型,比如文本框、下拉列表框、在线编辑器等。
3、 可以获取用户输入的数据,可以进行验证
4、 可以进行排版
5、 修改数据时,可以把原有数据绑定到表单。


实现方式:
1、 js + json + 第三方js脚本、控件
2、 json对表单进行描述,比如标题、控件类型、控件大小、下拉列表框的item如何填充等。
3、 第三方脚本实现复杂功能,比如选择日期、在线编辑、数据验证等。
4、 Js脚本根据json的描述,创建表单(table形式),创建表单里面的控件(比如文本框),然后对表单和控件进行修饰。
5、 提取用户输入的数据,然后进行验证。然后可以用ajax的方式提交给服务器。(提交部分表单控件不负责)。


思路:
1、 对表单进行归纳总结,抽象出来几种情况。比如有多少种控件、表格有几种表现形式。
其他的还没想好怎么表达出来。


使用方式:
使用就很简单了,因为俺比较懒,所以我做的东东,第一目标就是——用着省事。
1、 引用一堆js,其中自己的只有两个,一个创建控件,一个创建表单,还有一个验证数据。

2、 写一段“引导”脚本。这个基本是c#风格,当然也可以写成js风格。看个人喜好了。

        var Nature = {};
        Nature.Controls = {};
        
        var form;   //表单控件
        
        function create() {
            $("#divForm").html("");
            //创建表单
            var formEvent = {
                divID: "divForm",
                callback: formCallback   //回调函数
            };
            form = new Nature.Controls.Form(formEvent);
            form.create();

            $("#divButton").show();

        }
        
        function formCallback(formState) {
            switch (formState) {
            case 401:
                //查看
                 
                break;
            case 402:
                //添加
                 
                break;
            case 403:
            case 408:
                //修改
              
                break;

            }
            
        }

        //获取用户输入的信息
        function getValue() {
            //验证数据
            var re = checkData();

            if (!re) {
                return;
            }
            
            //获取用户输入的信息,json格式,然后可以ajax提交到数据库
            var value = form.getValue("dataForm");
           
            //下面仅在演示时用,显示用户输入了啥。
            var meta = eval("(" + $("#json").val() + ")");
            var controlInfo = meta.controlInfo;
            
            var re = "";
            for (var key in value) {
                var id = key.substring(1, key.length);
                re += controlInfo[id].ColName + ":   \t" + value[key] + "\n";
            }

            $("#msg").val(re);
        }

        function checkData() {
            //自带的验证功能。
            var re = CheckForm();

            if (re == true) {
                //验证通过,查看是否有自定义的js文件的验证
                if (typeof (cuscheck) != "undefined") {
                    //有自定义的验证,执行
                    re = cuscheck();
                }
            }
            return re;
        }

 


问与答:
问:为啥重复制造轮子?
答:搜索了一下js表单控件,没有发现特出名的。当然了肯定有做好的,只是我没有发现。再有也不是完全自己写的,有很多第三方现成的js拿来用的,比如my97。

问:写这个json也太复杂了,还不如自己做个表单方便。
答:这个json确实挺复杂的,但是他不是手动写出来的,而是自动生成的。原理类似于代码生成器。所以用起来还是挺方便的。

问:一个页面能放几个表单控件?
答:大于等于一个。因为是new出来的,所以每个表单控件都可以互补干扰。只要属性没有设置错误就可以区分开。

 

问:还有其他的功能吗?
答:当然还有其他的功能,比如设置文本框 只读(readonly),设置默认值,设置帮助信息,表单布局等,这些都可以通过修改json的属性值来实现。

问:json的结构到底是啥样的?
答:这个可以看在线演示,还可以修改值来看看变化。

 

附:第三方js
1、 jQuery。这个就不多说了。
2、 my97。选择日期的,很好很强大
3、 kindereditor。选择他是因为可以直接在页面里使用。因为是纯js的表单控件,所以服务器控件形式的在线编辑器是不好用了。
4、 数据验证。这个好像有很多已经很成熟的了,只是一直没时间研究。目前用的是一个比较古老的js脚本,出处已经不记得了。

在线演示:
js版的表单控件 : http://www.naturefw.com/demo/jsform.htm  (下面是一个iframe。好像有缓存。)
 
 
不知道大家是怎么处理表单的,有兴趣的话,欢迎一起聊聊!
 
 
相关文章
|
2月前
ractive.js联系表单动画效果源码
一款ractive.js联系表单动画效果,很有创意的发送邮件、联系内容等表单,基于ractive.js实现的动画效果,以发送信件的方式。
29 1
|
2月前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
60 3
|
3月前
|
JavaScript 数据安全/隐私保护
2024了,你会使用原生js批量获取表单数据吗
2024了,你会使用原生js批量获取表单数据吗
67 4
|
3月前
|
JavaScript 前端开发 数据安全/隐私保护
前端技术分享:使用Vue.js构建响应式表单
【10月更文挑战第1天】前端技术分享:使用Vue.js构建响应式表单
|
4月前
|
移动开发 前端开发 JavaScript
JavaScript 表单
JavaScript 表单
32 9
|
4月前
|
移动开发 JavaScript 前端开发
js之操作表单 | 12-4
js之操作表单 | 12-4
|
5月前
|
前端开发 微服务 API
微服务浪潮下的JSF革新:如何在分散式架构中构建统一而强大的Web界面
【8月更文挑战第31天】随着微服务架构的兴起,企业将应用拆分成小型、独立的服务以提高系统可维护性和可扩展性。本文探讨如何在微服务架构下构建和部署JavaServer Faces (JSF) 应用,通过RESTful服务实现前后端分离,提升灵活性和适应性。
71 1
|
4月前
|
人工智能 前端开发 JavaScript
react js 处理表单( form )的2个例子
react js 处理表单( form )的2个例子
|
5月前
|
大数据 数据处理 分布式计算
JSF 逆袭大数据江湖!看前端框架如何挑战数据处理极限?揭秘这场技术与勇气的较量!
【8月更文挑战第31天】在信息爆炸时代,大数据已成为企业和政府决策的关键。JavaServer Faces(JSF)作为标准的 Java Web 框架,如何与大数据技术结合,高效处理大规模数据集?本文探讨大数据的挑战与机遇,介绍 JSF 与 Hadoop、Apache Spark 等技术的融合,展示其实现高效数据存储和处理的潜力,并提供示例代码,助您构建强大的大数据系统。
70 0
|
5月前
|
Devops 持续交付 测试技术
JSF遇上DevOps:开发流程将迎巨变?一篇文章带你领略高效协同的魅力!
【8月更文挑战第31天】本文探讨了如何在JavaServer Faces(JSF)开发中融入DevOps文化,通过持续集成与部署、自动化测试、监控与日志记录及反馈机制,提升软件交付速度与质量。文中详细介绍了使用Jenkins进行自动化部署、JUnit与Selenium进行自动化测试、ELK Stack进行日志监控的具体方法,并强调了持续改进的重要性。
49 0