使用本机数据类型自动将表单输入编码为 JSON
Automatically encode form input to JSON with native datatype
我知道(来自 this)我可以在将值传递给 JSON.stringify
之前明确地将其转换为整数。但是当你想序列化一个表单数据时,这种方法就没有用了。我有一个通用代码:
let myform='#my_form_id`;
$(myform).submit(function(event) {
event.preventDefault();
const formData = new FormData($(myform)[0]);
const json = JSON.stringify(Object.fromEntries(formData));
ws.send(json); // send over websocket
});
而且我真的不想在序列化之前手动将每个字段转换为合适的类型。这违反了“编写良好”代码的所有规则。
那么,如何序列化 JSON 中的表单字段以保持它们的原始数据类型?
您可以map over the inputs and use a switch case选择返回的数据和类型。
$('form').on('submit', function(e) {
e.preventDefault();
let json = JSON.stringify($(this).find('input').get().map(function(input){
switch (input.type) {
case 'checkbox':
case 'radio': return input.checked; break;
case 'number':
case 'range': return +(input.value || 0); break;
default: return input.value || ''
}
}));
$('.json').html(json);
});
<form>
<div>
<input>
<input type="number">
<input type="checkbox">
<input type="radio">
<input type="color">
<input type="date">
<input type="range">
</div>
<div>
<input>
<input type="number">
<input type="checkbox">
<input type="radio">
<input type="color">
<input type="date">
<input type="range">
</div>
<button action="submit">SERIALIZE</button>
</form>
<p class="json"></p>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
我知道(来自 this)我可以在将值传递给 JSON.stringify
之前明确地将其转换为整数。但是当你想序列化一个表单数据时,这种方法就没有用了。我有一个通用代码:
let myform='#my_form_id`;
$(myform).submit(function(event) {
event.preventDefault();
const formData = new FormData($(myform)[0]);
const json = JSON.stringify(Object.fromEntries(formData));
ws.send(json); // send over websocket
});
而且我真的不想在序列化之前手动将每个字段转换为合适的类型。这违反了“编写良好”代码的所有规则。
那么,如何序列化 JSON 中的表单字段以保持它们的原始数据类型?
您可以map over the inputs and use a switch case选择返回的数据和类型。
$('form').on('submit', function(e) {
e.preventDefault();
let json = JSON.stringify($(this).find('input').get().map(function(input){
switch (input.type) {
case 'checkbox':
case 'radio': return input.checked; break;
case 'number':
case 'range': return +(input.value || 0); break;
default: return input.value || ''
}
}));
$('.json').html(json);
});
<form>
<div>
<input>
<input type="number">
<input type="checkbox">
<input type="radio">
<input type="color">
<input type="date">
<input type="range">
</div>
<div>
<input>
<input type="number">
<input type="checkbox">
<input type="radio">
<input type="color">
<input type="date">
<input type="range">
</div>
<button action="submit">SERIALIZE</button>
</form>
<p class="json"></p>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>