AForm

相信大部分程序员都接触过表单,表单是收集用户输入的不二之选,但是表单的开发又是最繁琐、最复杂的,简单地说,开发表单你需要涉及到很多知识:

  1. 布局,表单如何布局排版,看起来最清晰整洁,且符合用户体验
  2. 控件的选用,用select还是radio,用多选的select还是用复选框,有时还需要编写个性化的输入控件
  3. 数据有效性的验证、输入的提示文案等
  4. 针对个别输入控件的特殊设置,输入控件之间的联动
  5. 表单中如果有数据列表,那么你还需要编写内嵌表格以收集这些数据

以上这些随便哪一条都不是一件简单的工程,尤其是遇到复杂的表单,会令人更加头疼,但是一直以来,表单的开发鲜有敏捷的框架可用,我们可以找到表单的css框架、数据验证框架、数据填充或序列化函数,以及一些输入控件的组件,如日期选择器等,但我们很难找到一个统一的省事的表单框架,因此我们开发的表单很难复用、保持风格的一致以及进行高度的扩展。

那么是否有这样一种框架,让我们能够轻易创建风格统一、兼容各种浏览器以及高度定制的表单呢?答案是有!这里介绍一个组件,名叫json2form,可以轻易地把json数据转换成表单,无论json数据中是嵌套了多么复杂的数据,包含何种数据类型,甚至是数组,它都可以轻松应对。

json2form的介绍

json2form是一个可以把json数据转换成表单输入项的javascript组件,并可以轻松把输入的数据又还原成json,您仅需输入几行配置即可轻松生成各式各样的标准表单;在web系统中,只要您使用表单收集数据,相信您一定可以通过json2form来大大提高开发表单的效率。

主要特点:

  1. 使用和配置简单,仅包含3个函数,可快速上手
  2. 表单标准化,支持文本框、文本区域、单选框、复选框、下拉列表等各种输入控件
  3. 支持对数组元素的增删改操作
  4. 支持html5的新特性
  5. 支持输入验证,输入提示
  6. 可高度定制,支持自定义样式、界面以及各种验证处理函数

适用场景:

  • 各种WEB后台管理系统
  • 可由用户自定义表单的WEB前台系统
  • 任何使用表单收集用户数据的场合

现在我们来试验一下,把如下的数据生成表单:

{
  "Name": "张三丰",
  "Age": 32,
  "Height" : 165,
  "Married":true,
  "Sexy":1,
  "Hobby": "篮球,电影,旅行",
  "Address": {
    "Street": "南汇\"区xx路xx号",
    "City": "上海",
    "Country": "中国",
    "zipCode": "543210"
  },
  "Children": [
    {
      "Name": "小明",
      "Age": 7
    },
    {
      "Name": "小丽",
      "Age": 4
    },
    {
      "Name": "小淘",
      "Age": 3
    }
  ]
}

再加上一些配置代码,配置字段的名字、控件类型等:

{
        arrayIndex: {
            show: true
        },
        fields: {
            Name: { label: "姓名", readonly: true },
            Married: { label: "已婚" },
            Height: { label: "身高", required: true, type:"number" , ctrlAttr : {min:100,max:200,step:1} },
            Age: { label: "年龄", maxlength: 3, required: true, pattern: "\\d+", title: "请输入数字", tips: "小于100" },
            Sexy: { label: "性别", type: "radio", datalist: [{ value: 0, text: "男" }, { value: 1, text: "女"}] },
            Children: { label: "子女", noCreate: false, noDelete: false },
            Hobby: { label: "爱好" , required: true,cssText : "background:infobackground;border:1px solid gray", type: "checkbox", delimiter: ",", multiple: true, size: 5, datalist: ["烹饪", "音乐", "电影", "睡觉", "篮球", "旅行"] },
            Address: { label: "居住地址" },
            Street: { label: "街道",width:"300px", tips: "居住所在地" , inline:true },
            zipCode: { label: "邮政编码", tips: "居住所在地" , inline:true },
            City: { label: "城市",cssText:"", inline:true,ctrlCssText:"color:red",hideLabel:false, maxlength: 2, size: 15, tips: "hello" },
            Country: { label: "国家",width:"300px", inline:true, readonly: true, type: "select", datalist: [‘美国‘, ‘中国‘, ‘韩国‘] }
        }
    }
    

下面是最终生成的表单界面:

快速上手

使用json2form极其简单,您首先需在调用页面的head部分引入如下js文件和样式文件(样式文件是可选的):

<link href="aform.css" rel="stylesheet" />
<script src="aform.js"></script>

然后,准备好需要渲染的json数据和针对该数据的一些配置(同样也是json格式),以及用于显示表单的DOM容器(比如一个form或者div,假设命名为“divOutput”),最后像下面这样使用:

<script>
var jf = new AForm("divOutput",{
        arrayIndex : {
                show : true
        },
        fields:{
                Name:{label:"姓名",readonly:true},
                Sexy:{label:"性别",type:"radio",datalist:[{value:0,text:"男"},
                {value:1,text:"女"}]},
                Country:{label:"国家",readonly:true,type:"select",datalist:[
                ‘USA‘,‘CHINA‘,‘KOREA‘]}
        }
});
jf.render({
  "Name": "John Smith",
  "Sexy": 1,
  "Country":"CHINA"
});
</script>

这样就会在指定的容器中生成一组输入项,当您想收集用户数据时,执行getJsonString函数即可,该函数返回一个符合json标准的字符串:

<script>
jf.getJsonString();
</script>

下载和文档:

https://github.com/xiehuiqi220/AForm 
时间: 2024-08-02 23:35:43

AForm的相关文章

Delphi异形窗口之PNG

1 //1.单元内容 2 unit UnitAlienForm; 3 interface 4 uses 5 Windows, Forms, Classes, Graphics; 6 //从文件加载PNG 7 procedure AlienForm_PNGFromFile(AForm : TForm; AFileName : String); 8 //从资源加载PNG 9 procedure AlienForm_PNGFromResource(AForm : TForm; ResName : St

XE8 for iOS 状态栏的几种效果

XE8 实现 iOS 状态栏的几种效果: 一.状态栏底色: 开一个新工程. 设定 Fill.Color 颜色属性. 设定 Fill.Kind = Solid. 无需修改任何官方源码. 二.隐藏状态栏(全屏): 开一个新工程. 设定 BorderStyoe = None. 无需修改任何官方源码. 三.透明状态栏(能见底图): 开一个新工程. 设定底图 Fill.Bitmap.Bitmap. 设定 Fill.Bitmap.WrapMode = TitleStretch. 设定 Fill.Kind =

HTTP长连接实现“服务器推”的技术

HTTP长连接实现“服务器推”的技术快速入门及演示示例 在我的印象里HTTP是一种“无状态的协议”,也就是不知道以前请求的历史,无法保留上一次请求的结果.Cookie的诞生,弥补了这个不足,浏览器可以通过本地持久化请求数据来记录上次请求的环境.但这个没有根本上改变HTTP请求本身的这种“客户端请求服务器端相应”模式——客户端是主动的,而服务器是被动的.最近听说有“HTTP长连接”,去探索了一把,果然很有意思,能够实现“服务器推”的这种概念,也就是服务器是主动发送请求,客户端是被动接受请求.关于“

haha

HTML表单 在HTML中,表单是<form>...</form> 之间元素的集合,它们允许访问者输入文本.选择选项.操作对象和控制等等,然后将信息发送回服务器. 某些表单的元素 —— 文本输入和复选框 —— 非常简单而且内建于HTML 本身.其它的表单会复杂些:例如弹出一个日期选择对话框的界面.允许你移动滚动条的界面.使用JavaScript 和CSS 以及HTML 表单<input> 元素来实现操作控制的界面.与<input> 元素一样,一个表单必须指定

atitit agt sys 设置下级代理功能设计.docx

显示界面1 先查询显示 set_sub.js1 设置代理2 /atiplat_cms/src/com/attilax/user/AgentService.java3 显示界面 http://localhost:8080/agent/set_sub2.htm 先查询显示 set_sub.js // JavaScript Document function btn_click() { var sql="select * from account where id='$uid$' "; sq

atitit.atiOrm.js v2 q61 版本新特性.docx

1. V1新特性如下1 1.1. V2规划,直接生成sql在js端1 2. Orm设计框架图1 2.1. atiOrm.js的原理1 3. atiorm.js调用2 3.1. 查询数据2 3.2. 编辑数据(更新与新增)2 4. code2 1.1. V2新特性 对insert做优化测试.. 2. V1新特性如下 初步实现 2.1. V2规划,直接生成sql在js端 目前是在后端生成sql,前端以orm方式调用 多table的支持,一个form对应多个table,form的字段包括在多个tabl

Png异形窗口

同事演示了一个.NET的的PNG异形窗口.挺漂亮.于是也想用Delphi显摆一个. 关于Delphi用PNG做异形窗口的资料有不少.都是用GDIPlus或者TPNGImage组件加载PNG图像做的. 好在Delphi包装了微软的IWICImagingFactory接口,这样处理PNG的工作就交给操作系统去做了. 函数很简单一共就几行,关键就是UpdateLayeredWindow. 用Delphi2010提供的IWICImagingFactory接口的包装了,这次PNG的处理交给微软的操作系统了

仿苹果电脑任务栏菜单&amp;&amp;拼图小游戏&amp;&amp;模拟表单控件

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

Delphi 查找标题已知的窗口句柄,遍历窗口控件句柄(转)

Delphi 查找标题已知的窗口句柄,遍历窗口控件句柄(转) 用我的方法来控制其他程序窗体上的窗口控件,必须先了解什么是 回调函数.我的理解是这样的: 回 调函数写出来不是自己的程序去调用的,反而是让其他的东西去调用,比如windows操作系统,比如其他的程序等等之类的.但是什么时候被调用却不知道 了.回调函数一般是按照调用者的要求定义好参数和返回值的类型,你向调用者提供你的回调函数的入口地址,然后调用者有什么事件发生的时候就可以随时按照你 提供的地址调用这个函数通知你,并按照预先规定好的形式传