Ako razumem - formular se odnosi na definiciju kolona tabele (žao mi što liči na ponavljanje, ali bitno je da se nešto ne ispusti). Dakle, pored inputa u okviru ovih rowova (hehe, dobro zvuči :-) koji predstavljaju pojedine kolone tabele, postoji i input koji identifikuje samu tabelu (najverovatnije neki hidden). Tada se proces updatea svodi u stvari na brisanje svih postojećih zapisa iz baze koji se odnose na tu tabelu, i tek naknadni upis stanja definisanog na klijentskoj strani.
U tom slučaju ima smisla ostaviti isti obrazac s mogućnošću uklanjanja postojećih zapisa. Što se tiče pripreme inicijalnog stanja formulara, najlakše je generisati postojeće zapise sa serverske strane unutar rowova (prolazak kroz petlju s rezultatima iz baze i dodavanje value atributa na inpute i selected atributa na odabrane opcije). Dakako, moguće je odraditi inicijaciju i s klijentske strane, slično predloženoj modifikaciji funkcije addNewRow i uz pripremu JS strukture koja odgovara podacima iz baze, ali ne vidim potrebu za tim...
|