网页动态表单 ,网页动态参数

news2025/2/1 0:55:18

有的时候因为参数太多  无法  一一 创建   所有采用动态创建   自己遇到的一个实际情况今天写个例子

 

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>form demo</title>
    <link rel="stylesheet" href="https://www.layuicdn.com/layui-v2.5.5/css/layui.css" media="all">
	<script src="https://www.layuicdn.com/layui-v2.5.5/layui.js"></script>
	<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<style>
	.f {
		float: left;
	}

	.f1 {
		float: left;
		width: 150px;
		height: 23px;
	}

	.f2 {
		float: left;
		width: 90%;
		height: 23px;
	}
</style>
</head>

<body>
	
	<blockquote class="layui-elem-quote">
		<h2>动态表单    VX:Internetquant  </h2>
		<div class="layui-form layuimini-form">
			<!-- <form action="" method="post"> -->
				<div class="layui-form-item">
					<table class='layui-table'>
						<thead>
							<tr>
								<th>数据</th>
							</tr>
						</thead>
						<tbody id="form_data">

							<!-- <tr>
								<td>
									<p class="f">表单类型:</p>
									<select name="input_type" lay-ignore class="f1 input_type">
										<option value=""></option>
										<option value="hidden">隐藏域</option>
										<option value="select" selected>下拉</option>
										<option value="radio">单选按钮</option>
										<option value="text">文本</option>
										<option value="textarea">多行文本</option>
										<option value="file">上传</option>
										<option value="none">非表单</option>
										<option value="editor">富文本</option>
										<option value="checkbox">复选框</option>
										<option value="date">日期</option>
									</select>
									<p class="f">&ensp;&ensp;变量名:</p>
									<input name="name" value="solution_introduction" type="text"class="f1 name" />
									<p class="f">&ensp;&ensp;描述:</p>
									<input name="description" value="解决方案介绍" type="text" class="f1 description" />
									<br><br>
									<p class="f">&ensp;&ensp;参数数组:</p>
									<input name="data" value='{"value":"123","class":"ffa"}' type="text" class="f2 data" />
								</td>
							</tr> -->


						</tbody>
						<tfoot></tfoot>
					</table>

				</div>
				<div class="layui-form-item">
					<button class="layui-btn" lay-submit lay-filter="autoform" onclick="form_save()">立即提交</button>
					&ensp;&ensp;&ensp;&ensp;&ensp;&ensp;
					<button type="button" class="add_tr layui-btn">增加配置行</button>

				</div>
			<!-- </form> -->
		</div>
	</blockquote>

</body>

<script>
//初始化数据   有问题可以联系我  VX:Internetquant
var data ='[{"input_type":"select","name":"solution_introduction","description":"初始111","value":"123","class":"ffa","data":{"name":"xxx","value":"value"}},{"input_type":"text","name":"solution_introduction","description":"初始2222","value":"123","class":"ffa"}]';
        console.log(data)
        var data_array=JSON.parse(data);
        
        for(let item in data_array){
            var ini_select_data="";
            var ini_input_type="";
            var ini_name="";
            var ini_description="";
            var ss={};
            for(let it in data_array[item]){
                //console.log(it,'----',data_array[item][it])
                if(it=="input_type"){ini_input_type=data_array[item][it];continue}
                if(it=="name"){ini_name=data_array[item][it];continue}
                if(it=="description"){ini_description=data_array[item][it];continue}
                ss[it]=data_array[item][it];
            }
            //=========
            var trx='';
            if(ini_input_type=="hidden"){trx+='<option value="hidden" selected>隐藏域</option>';}else{trx+='<option value="hidden">隐藏域</option>';}
            if(ini_input_type=="select"){trx+='<option value="select" selected>下拉</option>';}else{trx+='<option value="select">下拉</option>';}
            if(ini_input_type=="radio"){trx+='<option value="radio" selected>单选按钮</option>';}else{trx+='<option value="radio">单选按钮</option>';}
            if(ini_input_type=="text"){trx+='<option value="text" selected>文本</option>';}else{trx+='<option value="text">文本</option>';}
            if(ini_input_type=="textarea"){trx+='<option value="textarea" selected>多行文本</option>';}else{trx+='<option value="textarea">多行文本</option>';}
            if(ini_input_type=="file"){trx+='<option value="file" selected>上传</option>';}else{trx+='<option value="file">上传</option>';}
            if(ini_input_type=="none"){trx+='<option value="none" selected>非表单</option>';}else{trx+='<option value="none">非表单</option>';}
            if(ini_input_type=="editor"){trx+='<option value="editor" selected>富文本</option>';}else{trx+='<option value="editor">富文本</option>';}
            if(ini_input_type=="checkbox"){trx+='<option value="checkbox" selected>复选框</option>';}else{trx+='<option value="checkbox">复选框</option>';}
            if(ini_input_type=="date"){trx+='<option value="date" selected>日期</option>';}else{trx+='<option value="date">日期</option>';}
            //=========
            var tr_data=`<tr>
            <td>
                <p class="f">表单类型:</p>
                <select name="input_type" lay-ignore class="f1 input_type">`+trx+`</select>
                <p class="f">&ensp;&ensp;变量名:</p>
                <input name="name" value="`+ini_name+`" type="text"class="f1 name" />
                <p class="f">&ensp;&ensp;描述:</p>
                <input name="description" value="`+ini_description+`" type="text" class="f1 description" />
                <br><br>
                <p class="f">&ensp;&ensp;参数数组:</p>
                <input name="data" value='`+JSON.stringify(ss)+`' type="text" class="f2 data" />
            </td>
            </tr>`;
            $('.layui-table').append(tr_data);
        }


        
        

        


        function form_save(){
            var form_array=[];
            var trList = $("#form_data").children("tr");
            for (var i=0;i<trList.length;i++) {
                var tdArr = trList.eq(i).find("td");
                
                var ss={};
                ss.input_type=tdArr.eq(1).find(".input_type").val();
                ss.name=tdArr.eq(1).find(".name").val();
                ss.description=tdArr.eq(1).find(".description").val();
                if(ss.name==""){
                    alert('序号'+i+1+':变量名不能为空')
                    return;
                }

                try {
                    var data=JSON.parse(tdArr.eq(1).find(".data").val());
                    for(var [key,value] of Object.entries(data)){
                        //console.log(key,value)
                        if(key=="input_type"){continue}
                        if(key=="name"){continue}
                        if(key=="description"){continue}
                        ss[key]=value;
                    }
                } catch(e) {
                    console.log('序号',i+1,':参数数组异常', e.message)
                    alert('序号'+i+1+':参数数组异常'+ e.message)
                    return;
                }

                form_array.push(ss);
            }

            console.log(form_array);
            var cc=JSON.stringify(form_array);     //字符串就可以提交使用了
            console.log(cc);
            console.log(JSON.parse(cc));
        }


        layui.use(['form', 'layer'], function () {
            var form = layui.form, i
            layer = layui.layer;
            $ = layui.$;
            $(function () {
                $('.layui-table').attr({ 'lay-size': 'sm', 'lay-skin': 'line' })
                $('.layui-table thead tr th:last').after("<th style=\"width: 80px;\">操作</th>")
                $('.layui-table thead tr th:first').before("<th>序号</th>")
                $('.layui-table tbody tr').each(function (i) {
                    $(this).find('td:first').before('<td>' + (i + 1) + '</td>')//渲染序号
                    $(this).find('td:last').after('<td> <button type="button" class="del_tr layui-btn layui-btn-danger layui-btn-sm">删除</button></td>')
                })
                
                //添加行
                $('.add_tr').bind('click', function () {
                    var tbody_dom = $('.layui-table').find('tbody');
                    var newtr = tbody_dom.find('tr:last').clone();
                    var aa = tbody_dom.find('tr:last').after(newtr);
                    tbody_dom.find('tr').each(function (i) {
                        // tbody_dom.find('tr:eq(' + i + ') td:eq(1) input').attr(site_config[" + i + "][name])  //
                        // tbody_dom.find('tr:eq(' + i + ') td:eq(2) input').attr(site_config[" + i + "][title])  //
                        // tbody_dom.find('tr:eq(' + i + ') td:eq(3) select').attr(site_config[" + i + "][type])  //
                        tbody_dom.find('tr:eq(' + i + ') td:first').html(i + 1)//渲染序号
                    })
                    //新增行input重置为空
                    tbody_dom.find('tr:last td:eq(1) input').val('');
                    tbody_dom.find('tr:last td:eq(2) input').val('');
                    tbody_dom.find('tr:last td:eq(3) select').val('');
                    form.render();
                })

                //删除行
                $('table.layui-table tbody').on('click', 'tr td .del_tr', function () {
                    var tbody_dom = $(this).parents('tbody');
                    var cnt = 0;
                    tbody_dom.find('tr').each(function (i) {
                        cnt++;
                    })
                    if (cnt <= 1) {
                        layer.alert('至少保留一行数据');
                        return false;
                    }
                    $(this).parents('tr').remove();
                    tbody_dom.find('tr').each(function (i) {
                        tbody_dom.find('tr:eq(' + i + ') td:first').html(i + 1)//渲染序号
                    })
                })
            })

        });
	
</script>

















</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/763022.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Windows查看电脑出厂时间

方法一&#xff1a;CMD命令查询 CMD输入命令 >systeminfoBIOS版本时间大概就是出厂时间

基于Mybatis-Plus的代码自动生成器

代码自动生成器 由于在普通业务开发中大多数增删改查操作都是重复的大量的&#xff0c;修改的内容也是相当的少&#xff0c;就如一个模版一样。所以在此构造一个基于Mybatis-Plus的代码生成器&#xff0c;旨在于快速生成项目结构和基础代码。 1、搭建环境 新建一个Springboo…

C语言实现通讯录——动态内存

好与不好&#xff0c;干嘛从别人口中找答案 大家好&#xff0c;我是纪宁。 考试周过去了&#xff0c;刚放暑假也陆陆续续有一些事&#xff0c;这两天才开始静下心来好好学习。希望你我都能过一个充实且快乐的暑假&#xff01; 今天的文章是用C语言实现一个动态版的通讯录 文章…

ARM基础(5):内存屏障的必要性、内存类型和内存排序

在我们写代码的过程中&#xff0c;经常会发现在SDK中会出现__ISB()或__DSB()等语句&#xff0c;这也做的目的是建立一个内存屏障&#xff0c;内存屏障可以由处理器内的硬件操作或内存屏障指令触发&#xff0c;它能够让CPU或编译器对屏障指令之前和之后的内存操作施加排序约束。…

cmake默认编译模式Debug or Release

CMAKE的编译选项 在阅读一些工程源码中&#xff0c;CMakeLists文件通常看到一下内容&#xff1a; set(CMAKE_CXX_FLAGS_DEBUG "-fPIC -O0 -g -Wall") set(CMAKE_CXX_FLAGS_RELEASE "-fPIC -O2 -g -Wall")那我们的编译时&#xff0c;用的到底是哪一个呢&a…

TypeScript 学习笔记(五):泛型

一、泛型是什么&#xff1f;有什么作用 软件工程中&#xff0c;我们不仅要创建一致的定义良好的API&#xff0c;同时也要考虑可重用性。 组件不仅能够支持当前的数据类型&#xff0c;同时也能支持未来的数据类型&#xff0c;这在创建大型系统时为你提供了十分灵活的功能。 在像…

【MySQL异常解决】Operation not allowed when innodb_forced_recovery > 0 的解决办法

Operation not allowed when innodb_forced_recovery > 0 的解决办法 一、背景描述二、解决方案三、拓展 一、背景描述 Spring Boot 项目&#xff0c;能正常启动&#xff0c;就是访问数据库时后台报错&#xff0c;Cause: java.sql.SQLException: Operation not allowed whe…

禁用 OPTIONS 请求

背景&#xff1a; 渗透测试结果为 不安全的HTTP方法 OPTIONS 描述 验证 curl -v -X OPTIONS http://localhost/xcall/token/refresh?_t1689589608解决方案&#xff08;2选1&#xff09;&#xff1a; 1.spring项目加上&#xff1a; import org.apache.tomcat.util.descript…

基于xinetd部署pwn题(百分百搭成并且可以nc靶场地址)

这种搭建方法需要你先装好docker&#xff0c;关于docker命令的安装这里就不过多介绍了&#xff0c;下面讲的是基于你已经安装好了docker&#xff0c;我们再使用xinetd在CTFd上部署pwn题目。 首先讲一下我自己搭建pwn题的一些经历&#xff0c;我最开始参考的是用socat命令来搭&a…

【DC-DC】APS54083 降压恒流驱动器大功率深度调光 舞台 RGB 汽车照明 台灯驱动芯片

产品描述 APS54083 是一款 PWM 工作模式,高效率、外围简单、外置功率 MOS 管&#xff0c;适用于 5-220V 输入高精度降压 LED 恒流驱动芯片。输出最大功率150W最大电流 6A。APS54083 可实现线性调光和 PWM 调光&#xff0c;线性调光脚有效电压范围 0.5-2.5V.PWM 调光频率范围 1…

MySQL第四章、表的增删查改(进阶)

目录 一、数据库约束 1.1约束类型 1.2NULL约束 1.3 UNIQUE&#xff1a;唯一约束 1.4 DEFAULT&#xff1a;默认值约束 1.5 PRIMARY KEY&#xff1a;主键约束 1.6 FOREIGN KEY&#xff1a;外键约束 1.7 CHECK约束&#xff08;了解&#xff09; 二、表的设计 2.1 一对一…

轻量级锁实现2——上锁、释放

瀚高数据库 目录 环境 文档用途 详细信息 环境 系统平台&#xff1a;Linux x86-64 Red Hat Enterprise Linux 7 版本&#xff1a;14,13,12,11 文档用途 从底层理解轻量级锁的实现&#xff0c;从保护共享内存的角度理解轻量级锁的使用场景&#xff0c;包括上锁、等待、释放&…

SpringCloud(二)Eureka简介与依赖导入

一、Eureka Eureka能够自动注册并发现微服务&#xff0c;然后对服务的状态、信息进行集中管理&#xff0c;这样当我们需要获取其他服务的信息时&#xff0c;我们只需要向Eureka进行查询就可以了。 像这样的话&#xff0c;服务之间的强关联性就会被进一步削弱。 二、服务注册与…

图像处理之梯度及边缘检测算子

文章目录 一、sobel 算子二、Scharr算子三、Roberts算子四、拉普拉斯算子 梯度是一个量变化的速度&#xff0c;在数学中通常使用求导、求偏导获取梯度或者某一方向上的梯度。 在数字图像中梯度可以看为像素值分别在x,y方向上的变化速度&#xff0c;因为数字图像的离散型&#x…

vue3 如何将页面生成 pdf 导出

原文链接&#xff1a;vue3 如何将页面生成 pdf 导出 前言 最近工作中有需要将一些前端页面(如报表页面等)导出为pdf的需求&#xff0c;博主采用的是html2Canvas jspdf。 步骤 1.引入两个依赖 npm i html2canvas npm i jspdf点击 jsPDF GitHub、jsPDF 文档 查看关于jsPDF更多…

连续两个季度利润暴跌95%以上,三星回不去了

这两年&#xff0c;小编本人电脑的 CPU、显卡等核心硬件毫无升级欲望不愿折腾。 反倒是内存条、固态硬盘容量不知不觉翻了好几倍! 老实说&#xff0c;对大多数像咱这样的普通用户来说&#xff0c;CPU、显卡从两三年前的主流型号升级到现在的主流型号&#xff1b; 价格明显上涨…

求助:交流耦合放大电路(HPF)的阻抗匹配问题

1、同向的交流耦合放大电路 电路如下图所示&#xff0c;信号源是一个上升时间1ns&#xff0c;下降时间15ns的脉冲信号&#xff0c;经过传输线的时延为5ns&#xff0c;然后通过放大器的同向交流耦合放大&#xff0c;这里我们可以明确的直到&#xff0c;下图中的R25就是端接电阻…

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现

课程设计总结 1 概述 1.1 项目开发背景 随着信息技术的快速发展&#xff0c;数字化管理已经成为各行各业提高效率和管理水平的重要手段。在图书管理领域&#xff0c;数字化管理系统可以有效地提高管理效率&#xff0c;提供更好的用户体验。本项目旨在开发一个基于Spring…

静态反射C++枚举名字的超简方案——C++闲得慌系列之(一)

C 有枚举&#xff0c;编译后其值就被转成整数了&#xff0c;有时程序会有输出枚举名字的需求&#xff0c;朴素的做法就是手工一个个写字符串&#xff08;名字&#xff09;&#xff0c;并实现匹配&#xff0c;比如&#xff1a; enum class Shape {rectangle, circular}; std::s…

再获信通院认可!华住&持安零信任项目获评零信任最佳方案奖!

2023年7月12日&#xff0c;在中国通信标准化协会算网融合产业及标准推进委员会&#xff08;CCSA TC621&#xff09;在京组织召开“2023算网融合产业发展峰会-零信任产业发展论坛”上&#xff0c;“2022零信任优秀案例”成果正式发布。 持安科技与华住集团共同完成的 “华住集团…