ユーザーが「複製」ボタンを押したときに、入力フィールドの個々の ID を動的に生成およびインクリメントするセクションのフォームを作成しています。たとえば、名前用に作成された入力フィールドの ID は「firstname1」であり、複製すると「firstname2」などになります。
私の問題は、私が構築しようとしているphpの「確認」ページにあります。大量のエコーをハードコーディングせずに、生成および入力されたすべての入力フィールドをエコーアウトしたい。個々の変数名の代わりに配列を使用するように言われました-概念はある程度理解していますが、不十分です。
すべての新しい入力の値をキャプチャする配列を作成しようとしたので、配列を $_POST し、各値をループしてエコーすることができますが、何を変更する必要があり、どこに実装する必要があるのか よくわかりません。
次のコードは、コンテナの div 全体と入力フィールドを複製し、クラス番号をインクリメントします。
$(#replicate').click(function(){
var $cloned = $('.container1').clone();
$cloned.find('input').val('');
$cloned.appendTo($('.emptyContainer'));
var container = $(".emptyContainer div").length;
var containerNumber = container + 1;
var containerClass = 'container' + containerNumber;
$(".emptyContainer .container1").attr("class", containerClass);
次に、入力 ID が同じ方法で増加します。
var fnameID = 'firstname' + containerNumber;
$('.emptyContainer #firstname1').attr({id: fnameID, name: fnameID});
姓、電話番号、電子メールなどを含む入力がさらにあります。
別のユーザーが提案しました:
foreach($_POST as $fieldName=>$fieldValue){
echo $fieldName." = ".$fieldValue."<br/>";
}
これで php ページにすべてが表示されましたが、すべてが 1 つの大きなブロックにまとめられていたため、後のスタイリングが少し面倒でした。
新しい入力ごとに入力値を取得し、それらを配列に保存し、ユーザーが送信を押したときに関連するすべての情報が関連する領域にとどまるように、それらをphp側に投稿するにはどうすればよいですか?