I decided to spend this weekend digging into the Framework and seeing how I could leverage JQuery features to create a better user experience. One of the more notable things I have come across to this point is the use of the JQuery Load function in place of User Control string generation.
One of my favorite techniques for loading Server driven content via JavaScript is to create an ASCX with the appropriate HTML template and then load its HTML via JavaScript from a web service based request. JQuery makes it very easy to append the HTML you get back and you can really encapsulate a lot of the heavy lifting inside the user control.
There really is no problem with this approach and I will still continue to use it for many things, however, with the routing mechanism that MVC offers you can greatly simplify the process by which this dynamic content is generated and gain greater flexibility for generating it. Let me explain:
I wont give a long overview of how routing works, if your interested, I invite you to read this blog post by Scott Guthrie for more information. Needless to say, I have a very basic routing setup with the following rule:
routes.MapRoute(
"Default",
"{controller}/{action}/{id}",
new { controller = "Home", action = "Index", id = 0 }
If we wanted to use the Action Link '/Test/EditSeries/14' to follow this route, we can expect to create a method EditSeries in our TestController which takes a single parameter for the 'id'. The method would then designate which view to use once the controller method completes its execution.
As for applying this to the Load method provided by JQuery, we have to simply understand that Load will make an HTTP request which will invoke the routing. Here is the JavaScript I am currently using:
$("#addGenre").click(function() { $("#genreContainer").append("<div class=\"genreSelect\"></div>"); $("#genreContainer").append("<br style=\"clear: both;\" />"); $("#genreContainer > .genreSelect:last").load("/Test/GenreSelect", null, function() { // setup the new slider SetupSlider($(this).find(".slider"), 0); SetupCloseIcon($(this).find(".removeGenre")); $(this).css("display", "block"); }); });You will notice that I am passing a valid MVC routing path to Load, this will cause the routing to invoke the GenreSelect method of the TestController class. I also defined GenreSelect.ascx in the same location as the View whose JavaScript is calling this "user control view". Thus my controller code for this operation looks like such:
public ActionResult GenreSelect() { ViewData["Genres"] = Genres.GetAllGenres(Context); return View("Series/GenreSelect"); }
Notice how simple this code is, and this is all that needs to be done to prepare the "partial" view.
The basic premise of this posting is to show how you can leverage some of the automated content loading features of JQuery and the MVC routing system to simplify this sort of an operation. It also makes more sense given the premise of what we are doing.
11 comments:
Your using hard coded routes in your example..e.g
$("#genreContainer > .genreSelect:last").load("/Test/GenreSelect", null,....
This will break severely if you ever change your routing definition (for example adding ".mvc" to the controllers to make your site work with IIS 6). You will need to manually update all of your links in your code which is definately NOT Dry. You should be using the Html.Actionlink helper, however this leaves you with a dilemma when coding javascript, as now your javascript code will need to be interpreted by a view engine, and can't simply be served from the /Scripts folder. It will be interesting to see how the MS Dev team address these kinds of dilemma's.
I would suggest using UFrame, which is like UpdatePanel for ASP.NET MVC:
http://www.codeplex.com/uframe
This uses jQuery or MS AJAX, whatever framework you have. It works in regular ASP.NET project, as well as, ASP.NET MVC project.
I found this site using [url=http://google.com]google.com[/url] And i want to thank you for your work. You have done really very good site. Great work, great site! Thank you!
Sorry for offtopic
[url=http://platinconne.freehostia.com/map.html]free movies download[/url] parampampam!
дом 2 за камерой фото интим
индивидуалки калининграда
училка мулатка выезд
личные домашние интим фото
зрелые женщины ищут интим за деньги в казани
индивидуалки м новые черемушки
семеновская интим
проститутки м бабушкинская
усинск проститутки
самара лесби
интим в мурманске
пермь знакомства
интим города альметьевска
трансы в челябинске
семейная пара на приеме у госпожи
лесби танцы
молоденькие лесби
cialis duration of effectiveness
cialis from canada
cialis and zoloft interactions
which is better cialis or levitra
ingredient in cialis
cialis naion
difference between cialis and levitra
u 222 cialis
cialis generic online
boeing regence cialis
[url=http://buyviagrapills24h.com/]buy cheap viagra pills[/url]
adults search
adult pic bbs
bleeding pussy sex
black sex free
forever baby adult
sexy grils bums for smacking
all russian sex free
private secure adult media
[b][url=http://pohudey.in]ХУДЕЙ БЕЗ ПРОБЛЕМ!![/url][/b]
[url=http://pohudey.in][img]http://harizzzma.com/dieta1.jpg[/img][/url]
диета после беременности
сколько есть чтобы похудеть
результаты похудения фото
простые диетические рецепты
диета бодибилдинг
мягкие капсулы для похудения dali
технология похудения 25 кадр
правильное питание википедия
диета отруби
генетическая диета
удаление желчного пузыря диета 5
диета 21 день
как похудела наталья бочкарева
самая быстрая и эффективная диета
викторина о здоровом питании
диета для спермы
недельная гречневая диета
цветная капуста диетические рецепты
медовая диета
эффективность кефирной диеты
старинные рецепты похудения
как похудеть форум
бодибилдинг похудеть
клизма для похудения
вулкан для похудения
как похудела анастасия дашко
какие таблетки пить чтобы похудеть
диета при переломах
комплекс упражнений бодифлекс для похудения
гречневая диета вторая группа крови
гречневая диета рецепт
туберкулез диета
слабительное для похудения
тыква диета
скачать бесплатно аудиотренинг для похудения
диета система минус 60
оксалатурия диета
бабушкины рецепты для похудения
как похудеть навсегда
нано методика гарантированное похудение бесплатно
правильно похудеть
25 кадр похудение torrent
как быстро похудеть в домашних условиях
худеем без проблем
диета доктор борменталь
таблица продуктов белки углеводы
как похудеть за пару дней
можно ли похудеть от секса
как похудеть на 20 кг за 20 дней
онлайн гимнастика для похудения
составить методику похудения бесплатно
гипотиреоз как похудеть
как похудеть за пол года
диета 30 плюс
похудевшие знаменитости фото
таблицы роста и веса для детей
эффективны ли пластыри для похудения
здоровое питание в россии
90 дней раздельного питания
беседа о здоровом питании
опасна ли кефирная диета
капсулы для похудения идеал
похудеть за неделю фрукты
диета стройность
аллен карр похудеть
диеты для желающих похудеть
остеопороз диета
горчичные ванны для похудения
здоровье как похудеть
малышева здоровье похудение
яблочно кефирная диета
белковая диета для женщин
методика похудения доктора борменталя
как похудеть на 4 кг
как быстро похудеть в ногах
белковая диета отзывы
похудеть навсегда скачать бесплатно
центр похудения технология красоты отзывы
[url=http://lengbadlipank.freehostia.com]как похудеть[/url]
Hi
Costume Jewellery Watches, items on auctions & discount prices on
[url=http://aerowatches.my3gb.com]chronoswiss watches[/url]
[url=http://dieselwatch.freehostking.com]citizen watch collection[/url]
[url=http://eoswatches.10fast.net]citizen watches discount[/url]
[url=http://watches.awardspace.us]concord watches[/url]
[url=http://repwatch.bravehost.com]corum mens watch[/url]
Post a Comment