bootstrap dynamic inputGroup

<!DOCTYPE html>

<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
	<head>
		<meta charset="utf-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u"
		 crossorigin="anonymous">
		<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
		<script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa"
		 crossorigin="anonymous"></script>
		<title></title>
	</head>
	<body>
		<div class="container">
			<div class="input-group-add">
			</div>

			<button type="button" class="btn btn-primary" id="testV">获取input数组</button>
		</div>
		<script>
			$('#testV').click(function() {
				var arr = [];
				$("input[name='data[]']").each(function() {
					arr.push($(this).val());
				})
				console.log(arr);
			});


			$(function() {
				$.fn.initInputGroup = function(options) {
					//1.Settings 初始化设置
					var c = $.extend({
						widget: 'input',
						add: "<span class=\"glyphicon glyphicon-plus\"></span>",
						del: "<span class=\"glyphicon glyphicon-minus\"></span>",
						field: '',
						data: []
					}, options);

					var _this = $(this);

					//添加序号为1的输入框组
					addInputGroup(1);

					/**
					 * 添加序号为order的输入框组
					 * @param order 输入框组的序号
					 * @param data 初始化输入框组中的数据
					 */
					function addInputGroup(order) {

						//1.创建输入框组
						var inputGroup = $("<div class='input-group' style='margin: 10px 0'></div>");
						//2.输入框组的序号
						var inputGroupAddon1 = $("<span class='input-group-addon'></span>");
						//3.设置输入框组的序号
						inputGroupAddon1.html(" " + order + " ");

						//4.创建输入框组中的输入控件(input或textarea)
						var widget = '',
							inputGroupAddon2;
						if (c.widget == 'textarea') {
							widget = $("<textarea class='form-control' style='resize: vertical;'></textarea>");
							widget.html(c.data[order - 1]);
							inputGroupAddon2 = $("<span class='input-group-addon'></span>");
						} else if (c.widget == 'input') {
							widget = $("<input class='form-control' type='text'/>");
							widget.val(c.data[order - 1]);
							inputGroupAddon2 = $("<span class='input-group-btn'></span>");
						}

						//5.设置表单提交时的字段名
						if (c.field.length == 0) {
							widget.prop('name', c.widget + 'Data[]');
						} else {
							widget.prop('name', c.field + '[]');
						}


						//6.创建输入框组中最后面的操作按钮
						var addBtn = $("<button class='btn btn-default' type='button'>" + c.add + "</button>");
						addBtn.appendTo(inputGroupAddon2).on('click', function() {
							//7.响应删除和添加操作按钮事件
							if ($(this).html() == c.del) {
								$(this).parents('.input-group').remove();
							} else if ($(this).html() == c.add) {
								$(this).html(c.del);
								addInputGroup(order + 1);
							}
							//8.重新排序输入框组的序号
							resort();
						});

						inputGroup.append(inputGroupAddon1).append(widget).append(inputGroupAddon2);

						_this.append(inputGroup);

						if (order + 1 > c.data.length) {
							return;
						}
						addBtn.trigger('click');
					}

					function resort() {
						var child = _this.children();
						$.each(child, function(i) {
							$(this).find(".input-group-addon").eq(0).html(' ' + (i + 1) + ' ');
						});
					}
				}
			});



			$(function() {
				$('.input-group-add').initInputGroup({
					'widget': 'input', //输入框组中间的空间类型
					// 'add' : '添加',
					// 'del' : '删除',
					'field': 'data',
					'data': ['haha', 'hello', 'hi', 'dj']
				});
			});
		</script>

	</body>
</html>

在使用Jinja2模板引擎、Bootstrap 3样式和jQuery插件来满足这个前端动态输入框的需求时,首先确保已安装了必要的库,然后你可以创建一个基础HTML结构,并利用JavaScript来动态生成输入元素。下面是一个简单的示例: ```html <!DOCTYPE html> <html lang="en"> <head> <title>Dynamic Input Form</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css"> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> <!-- Include Bootstrap JavaScript for forms --> <script src="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script> <script> $(document).ready(function() { function addInputFields(num) { // 动态添加一组新的输入框 var inputWrapper = '<div class="form-">属性</label><input type="text" class="form-control" id="input-' + num + '"></div>'; $('#input-container').append(inputWrapper); // 添加数量选择框 var quantitySelect = '<div class="form-group"><label for="quantity">数量</label><select class="form-control" id="quantity' + num + '"><option value="1">1</option><option value="2">2</option><option value="3">3</option></select></div>'; $('#input-container').append(quantitySelect); // 添加删除按钮 var deleteButton = '<button type="button" class="btn btn-danger remove-input" data-index="' + num + '">删除</button>'; $('#input-container').append(deleteButton); } // 初始化一个输入框 addInputFields(0); // 点击事件处理函数,动态增加输入框 $('.add-button').click(function(e) { e.preventDefault(); var num = parseInt($(this).data('index')) + 1; addInputFields(num); }); // 删除输入框的事件监听 $(document).on('click', '.remove-input', function() { var index = $(this).data('index'); $(`#input-${index}, #quantity${index}`).remove(); }); }); </script> </head> <body> <div class="container"> <h2>动态输入表单</h2> <div id="input-container"> <!-- 输入框将在这里动态生成 --> <div class="form-group"> <label for="input-0">属性</label> <input type="text" class="form-0"> </div> <div class="form-group"> <label for="quantity0">数量</label> <select class="form-control" id="quantity0"><option value="1">1</option><option value="2">2</option><option value="3">3</option></select> </div> <button type="button" class="add-button btn btn-success" data-index="0">+ 添加更多</button> </div> </div> </body> </html> ``` 在这个例子中,我们使用jQuery创建了一个按钮用于触发新输入框的添加,以及一个点击事件处理器来动态插入新元素。当用户点击“+ 添加更多”按钮时,会增加一个新的输入组。每个输入组包含文本输入框、数量选择器和删除按钮。当用户点击删除按钮时,对应的内容会被移除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值