Abbiamo estrarre i dati da server e per questo Se stiamo usando Struts, allora possiamo tirare sia presentando una pagina che MVC Architettura o abbiamo cam effettuare una chiamata di AJAX ma convenzioni è di utilizzare forme e renderemo la risposta, ma affrontiamo anche sfide per offrire un'esperienza utente ricca, quindi scendiamo a compromessi con le convenzioni e iniziamo ad usare l'AJAX eccessivo, quindi come dovremmo fare equilibrio tra due?AJAX vs Modulo di presentazione
risposta
Personalmente penso che AJAX dovrebbe essere utilizzato per gli aggiornamenti dei display e l'invio dei moduli deve essere eseguito tramite una ricarica della pagina. Ragionamento?
Quando si inoltrano i moduli, si sta dicendo all'applicazione di fare qualcosa. Gli utenti tendono a voler sentire che è stato fatto. Quando una pagina non viene ricaricata, spesso gli utenti si chiedono "Ha funzionato?". Quindi devono verificare che ciò che hanno fatto sia giusto.
D'altra parte, quando si visualizza un grafico o qualcosa del genere e l'utente dice di "visualizzare dati 2011 .... ora dati 2012", ad esempio, non sta "facendo" qualcosa (creando nuove entità , invio di e-mail, ecc.). Quindi AJAX può fornire una bella interfaccia utente in questo caso. Le ricariche delle pagine sarebbero fastidiose qui.
In conclusione, penso che l'invio di moduli debba essere eseguito tramite ricariche di pagina (lasciare che l'utente lo veda funzionante), mentre gli aggiornamenti di visualizzazione dovrebbero utilizzare AJAX (evitare fastidiose ricariche di pagina).
Naturalmente, questa è una cosa di preferenza. Alcune delle applicazioni della mia azienda utilizzano AJAX dappertutto. Ma quelle sono le applicazioni più difficili da mantenere e eseguire il debug.;)
Se si verificano errori tra l'invio di dati, l'unico metodo di moduli che è possibile controllare sul server. D'altra parte, se si effettuano chiamate Ajax, è possibile verificare gli errori sul lato client. Quindi, da questa diversa tecnologia di trasmissione dei dati potremmo seguire una decisione che servono a scopi diversi.
L'invio di moduli HTML vecchi e di forme ajax di fantasia non si escludono a vicenda.
Innanzitutto, rendere il semplice modulo HTML funzionante correttamente. Quindi, aggiungi javascript per dirottare il modulo e inviare una richiesta Ajax.
Il controller e il modello non si preoccupano se il browser dell'utente supporta (o ha abilitato) javascript. La visualizzazione renderizzata viene decisa in base al fatto che la chiamata sia stata effettuata con javascript o una semplice sottomissione di modulo. Questo è uno dei punti di forza del pattern MVC, non un vincolo.
ritengo che la scelta tra i due è alquanto intrinseca:
un modulo di presentazione è sincrona e ricarica la pagina.
una chiamata ajax è asincrona e non ricarica la pagina.
Se una certa azione cambierà un sacco di elementi dell'interfaccia utente o deve interrogare un sacco di dati che devono essere resi, vorrei andare con modulo di presentazione. D'altra parte, se una determinata azione viene utilizzata per azioni semplici, come la compilazione di una casella di selezione o il miglioramento dell'esperienza utente, farei una chiamata AJAX.
Non c'è niente che ti evita di usare quante chiamate Ajax o moduli di invio di cui hai bisogno, quindi alla fine dipende da te.
- 1. AJAX modulo di presentazione - Non ci sono dati restituiti
- 2. l'invio di dati pubblicare con jQuery sul modulo di presentazione
- 3. Come controllare modulo di presentazione ASP classico
- 4. script di un modulo Google docs presentazione
- 5. chiudi finestra extjs dopo modulo di presentazione
- 6. Facendo clic su Indietro dopo Fancybox AJAX formulario di presentazione
- 7. Redirect su presentazione del modulo con window.location.href
- 8. AngularJS - Prevenire presentazione di un modulo se esso è valido
- 9. Yii2: convalida del modulo Ajax su un modulo inviato Ajax
- 10. Screenscaping aspx con Python Mechanize - Javascript modulo di presentazione
- 11. Ripristinare il valore del textarea dopo modulo di presentazione
- 12. Summernote e modulo di presentazione in MVC C#
- 13. Lottando con recaptcha v2 e modulo di presentazione
- 14. JS angolari - pulsante sul Modulo di sopprimere presentazione
- 15. php ritorno alla pagina dopo modulo di presentazione
- 16. Modulo AJAX e DJANGO
- 17. Comet VS sondaggio Ajax
- 18. CakePHP: JSON vs AJAX
- 19. Ajax vs Socket.io
- 20. Modulo standard Invia vs Modulo Ajax Invia - Salva automaticamente browser/Suggerisci input utente
- 21. iframe vs Ajax
- 22. Modulo di login di Django Ajax
- 23. php, modulo utilizzando la stessa pagina dopo la presentazione
- 24. Invia modulo con jquery ajax
- 25. Invia modulo laravel utilizzando AJAX
- 26. valori di modulo chiari dopo l'invio ajax
- 27. Reindirizzare dall'interno di un modulo Ajax post
- 28. Integrazione modulo di iscrizione AJAX Mailchimp
- 29. Modulo di invio AJAX utilizzando Bottle (Python)
- 30. Modulo di contatto 7 AJAX Callback
Si potrebbe voler riconsiderare il modo in cui si pensa ajax. Vuoi veramente ricaricare la pagina quando fai l'upvote o fare un commento su SO? ajax fatto bene è pulito e degrada con grazia. (Inoltre, un aspetto datato, ma comunque significativo, specialmente con i dispositivi mobili: ajax può risparmiare larghezza di banda.) – bdares
Sono d'accordo. Stavo parlando più di "invio di moduli" come compilare un modulo. Se il tuo cambiamento non è enorme, accetto di usare AJAX. Stavo pensando di più "aggiungi tutti questi dati al database", ecc. –
"Utile" upvote per averlo indicato. Ty. :) –