- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找一种方法来保存多个 <input>
中的表值形成字段,并能够恢复它们。为什么 - 我需要一种在英制和公制系统之间切换的方法,而不会在转换过程中损失精度。
所以我下面有一些代码,假设值是用英语单位系统输入的。如果用户随后切换到公制,the values are converted
对于用户来说。现在切换回英语没有任何作用,因为虽然我可以进行反向转换,但这样做最终会失去精度。我不知道如何解决保存和恢复多个值的问题,我想要表单做的是 restore originally entered values
当用户切换到英语时。我想我首先需要有一种方法来保存原始输入的值。
尝试下面的代码时,首先将选择从英制更改为公制。您将看到所有值都更改为某个转换后的值。回到英语没有任何作用。 “保存”和“恢复”按钮现在也不起作用。此外,各个值之间没有区别,因为我不知道如何对它们进行编码。我不想为每个人分配唯一的 ID,除非必须这样做。 (因此,即现在输入您自己的值将被忽略,并且当您进行转换时,只有第一行第一个单元格才会影响其余单元格,因为我对单元格使用类选择器,而不是单独选择它们)
我需要什么帮助:
编辑以提及 PHP:
“添加行”在这里只是以编程方式执行任何操作,但这意味着可以添加更多行。现在它是通过 PHP 完成的——向服务器后端发出表单帖子,并且页面刷新并添加一行。因此,如果需要的话,有一种方法可以使用 PHP 生成一些 HTML。例如,解决方案不必只是前端,但我认为 PHP 和前端耦合得越松散越好。因此,如果有一个仅前端(JS/jQuery)的解决方案,我会首先选择它,而不是混合 JS/PHP 方法,但我会接受两者。
$("#unit_system").change(function() {
if ($('#unit_system').val() == "Metric")
{
$(".input_gpm").val(convert($(".input_gpm").val(),'gpm','m3h'));
}
});
function convert(val, from, to)
{
var conv = [];
conv["m3h"] = 1 / 3600;
conv["gpm"] = 6.3090196485533854530026767050539e-5;
return val * conv[from] / conv[to];
};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form id="my_form">
<select id="unit_system">
<option value="English">English</option>
<option value="Metric">Metric</option>
</select>
<button id="save_values" type="button">Save Values</button>
<button id="restore_values" type="button">Restore Values</button>
<table id="values">
<tr>
<td>Row 1</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td>Row 2</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td>Row 3</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td colspan="3"><button>Add Row...</button></td>
</tr>
</table>
</form>
最佳答案
您可以使用jQuery.data()存储和检索页面上每个输入的任意数据。我在下面创建了一个可运行的示例。看一下我为代码底部的“保存”和“恢复”按钮创建的处理程序。
编辑:我刚刚看到了“添加行”按钮的要求,我也为此添加了一个事件处理程序。
$("#unit_system").change(function() {
if ($('#unit_system').val() == "Metric") {
$(".input_gpm").val(convert($(".input_gpm").val(),'gpm','m3h'));
}
});
function convert(val, from, to) {
var conv = [];
conv["m3h"] = 1 / 3600;
conv["gpm"] = 6.3090196485533854530026767050539e-5;
return val * conv[from] / conv[to];
};
$("#save_values").on("click", function() {
$("input").each(function() {
$(this).data("restore", $(this).val());
});
});
$("#restore_values").on("click", function() {
$("input").each(function() {
$(this).val($(this).data("restore"));
});
});
$("#addNew").on("click", function() {
var lastDataRow = $("#values tr:nth-last-of-type(2)");
var newDataRow = lastDataRow.clone();
newDataRow.find("td:first").html("Row " + $("#values tr").length);
lastDataRow.after(newDataRow);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form id="my_form">
<select id="unit_system">
<option value="English">English</option>
<option value="Metric">Metric</option>
</select>
<button id="save_values" type="button">Save Values</button>
<button id="restore_values" type="button">Restore Values</button>
<table id="values">
<tr>
<td>Row 1</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td>Row 2</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td>Row 3</td>
<td><input class="input_gpm" type="text" value="4" /></td>
<td><input class="input_gpm" type="text" value="4" /></td>
</tr>
<tr>
<td colspan="3"><button id="addNew">Add Row...</button></td>
</tr>
</table>
</form>
关于javascript - 如何保存和恢复表单字段内的多个值(仅使用前端逻辑),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26873100/
我尝试根据表单元素的更改禁用/启用保存按钮。但是,当通过弹出按钮选择更改隐藏输入字段值时,保存按钮不受影响。 下面是我的代码。我正在尝试序列化旧的表单值并与更改后的表单值进行比较。但我猜隐藏的字段值无
我正在尝试保存模型的实例,但我得到了 Invalid EmbeddedDocumentField item (1) 其中 1 是项目的 ID(我认为)。 模型定义为 class Graph(Docum
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
目前,我正在使用具有排序/过滤功能的数据表成功地从我的数据库中显示图像元数据。在我的数据表下方,我使用第三方图像覆盖流( http://www.jacksasylum.eu/ContentFlow/
我的脚本有问题。我想按此顺序执行以下步骤: 1. 保存输入字段中的文本。 2. 删除输入字段中的所有文本。 3. 在输入字段中重新加载之前删除的相同文本。 我的脚本的问题是 ug()- 函数在我的文本
任何人都可以帮助我如何保存多对多关系吗?我有任务,用户可以有很多任务,任务可以有很多用户(多对多),我想要实现的是,在更新表单中,管理员可以将多个用户分配给特定任务。这是通过 html 多选输入来完成
我在 Tensorflow 中训练了一个具有批归一化的模型。我想保存模型并恢复它以供进一步使用。批量归一化是通过 完成的 def batch_norm(input, phase): retur
我遇到了 grails 的问题。我有一个看起来像这样的域: class Book { static belongsTo = Author String toString() { tit
所以我正在开发一个应用程序,一旦用户连接(通过 soundcloud),就会出现以下对象: {userid: userid, username: username, genre: genre, fol
我正在开发一个具有多选项卡布局的 Angular 7 应用程序。每个选项卡都包含一个组件,该组件可以引用其他嵌套组件。 当用户选择一个新的/另一个选项卡时,当前选项卡上显示的组件将被销毁(我不仅仅是隐
我尝试使用 JEditorPane 进行一些简单的文本格式化,但随着知识的增长,我发现 JTextPane 更容易实现并且更强大。 我的问题是如何将 JTextPane 中的格式化文本保存到文件?它应
使用 Docker 相当新。 我为 Oracle 11g Full 提取了一个图像。创建了一个数据库并将应用程序安装到容器中。 正确配置后,我提交了生成 15GB 镜像的容器。 测试了该图像的新容器,
我是使用 Xcode 和 swift 的新手,仍在学习中。我在将核心数据从实体传递到文本字段/标签时遇到问题,然后用户可以选择编辑和保存记录。我的目标是,当用户从 friendslistViewCon
我正在用 Java 编写 Android 游戏,我需要一种可靠的方法来快速保存和加载应用程序状态。这个问题似乎适用于大多数 OO 语言。 了解我需要保存的内容:我正在使用策略模式来控制我的游戏实体。我
我想知道使用 fstream 加载/保存某种结构类型的数组是否是个好主意。注意,我说的是加载/保存到二进制文件。我应该加载/保存独立变量,例如 int、float、boolean 而不是结构吗?我这么
我希望能够将 QNetworkReply 保存到 QString/QByteArray。在我看到的示例中,它们总是将流保存到另一个文件。 目前我的代码看起来像这样,我从主机那里得到一个字符串,我想做的
我正在创建一个绘图应用程序。我有一个带有 Canvas 的自定义 View ,它根据用户输入绘制线条: class Line { float startX, startY, stopX, stop
我有 3 个 Activity 第一个 Activity 调用第二个 Activity ,第二个 Activity 调用第三个 Activity 。 第二个 Activity 使用第一个 Activi
我想知道如何在 Xcode 中保存 cookie。我想使用从一个网页获取的 cookie 并使用它访问另一个网页。我使用下面的代码登录该网站,我想保存从该连接获得的 cookie,以便在我建立另一个连
我有一个 SQLite 数据库存储我的所有日历事件,建模如下: TimerEvent *Attributes -date -dateForMark -reminder *Relat
我是一名优秀的程序员,十分优秀!