Non-javascript fallbacks in ASP.NET MVC
This post was originally published on Coding Glamour.
Alles op den ganse aarde is tegenwoordig Ajaxified, en een behoorlijk
aantal websites heeft haar Ajax interacties Javascript-only gemaakt. Nogal
vervelend als een aanzienlijk deel van je gebruikers onder werktijd je
website probeert te gebruiken. Met ASP.NET MVC is het behoorlijk gemakkelijk
gemaakt om eenvoudige interacties ook beschikbaar te maken voor non-Javascript
clients.
De 'Bewaren' knop
Men neme als voorbeeld, de 'Bewaren als favoriet' functionaliteit
zoals deze op elke detailpagina te zien is. Een knop met drie states:
Here used to be an image. It was lost in the great accidental deletion of 2013...
Here used to be an image. It was lost in the great accidental deletion of 2013...
Here used to be an image. It was lost in the great accidental deletion of 2013...
Aan de achterkant doet dit niets anders dan een GET naar de controller 'ClientActie' (GETs zijn goedkoper dan POSTs) via:
En nu zonder Javascript?!
Allereerst is het zaak om altijd een werkende link te hebben achter een knop. Wanneer je 'Telefoon' linkje normaal direct het telefoonnummer toont, zorg er dan voor dat de <a href/> naar je contact-pagina wijst. Zo breek je je interactie niet. Voor het 'Bewaren' linkje hebben we de volgende link:
Als de gebruiker nu klikt, wordt hij doorgestuurd naar '/huidigepagina/?clientactie=bewaarobject'. We moeten dit nu enkel afvangen in de controller die deze pagina serveert.
Action filter
In ASP.NET MVC kan je 'action filters' gebruiken om via attributes op je actions generiek gedrag te implementeren. Een filter voor de 'clientactie' behavior ziet er ongeveer zo uit:
Nu kan je je Action decoraten met het attribute:
Et voila! Bij elke aanroep wordt bekeken of er nog clientacties zijn die verwerkt moeten worden.
View
In de view hoeven we geen wijzigingen te maken omdat er hier geen verschillen zijn tussen de Javascript en de non-Javascriptgebruiker (pseudo-code):
There are 13 comments on this article, read them on Coding Glamour.