2 つのフォーム フィールドがあり、両方に値がある場合にのみ、jquery を使用してこれらの値を投稿したいと考えています。私はこれを試しましたが、もっと良い方法があるはずです。この方法ではエラーが発生する可能性があると思います
$('#RFID').change(function(e){
if($(this).val() != '' && $('#STATION_ID').val() != ''){
}
});
2 つのフォーム フィールドがあり、両方に値がある場合にのみ、jquery を使用してこれらの値を投稿したいと考えています。私はこれを試しましたが、もっと良い方法があるはずです。この方法ではエラーが発生する可能性があると思います
$('#RFID').change(function(e){
if($(this).val() != '' && $('#STATION_ID').val() != ''){
}
});
それは特に悪いアプローチではありません。少しはきれいになるかもしれませんが。私は次のようなものに行きます:
var $fields = $('#RFID, #STATION_ID').change(function(e) {
if ($fields[0].val() && $fields[1].val()) {
// post it
}
});
$('form').submit(function(e) {
if (!$fields[0].val() || !$fields[1].val()) e.preventDefault();
});
投稿する前に、同じチェックを行うだけです。
if ($.trim($('#RFID').val()) != '' && $.trim($('#STATION_ID').val()) != '') {
// do post
}
おそらく、フォームの自動送信を生成できるすべてのフィールドに on change ハンドラーを割り当てるでしょう。
おそらく、自動送信に参加できる各フィールドに対してクラスを追加します。
私が知っているコードはもう少しありますが、インテントを設定し、検証をすべて 1 か所で収集します。
それが役に立てば幸い。
$('.auto-submit').change(function(e) {
// collect all the auto submit fields and make sure they are not empty
for( field in $('.auto-submit') )
if( field.val() == '' ) return; // all fields not there
}
// do form submit here
} );