开发者

jquery-mobile backbone.js routing

I have a backbone.js / jquery mobile app:

when i make a GET to mydomain.com/#map, then jquery executes "/" and then loads #map.

because "/" is triggered first, all backbone.js scr开发者_JAVA百科ipts are loaded including the backbone.js routes in my map-controller.js ("map": "functionForMapRoute"). since the URL contains /#map, the backbone.js route "map" gets triggered before jquery mobile has rendered the dom.

so "functionForMapRoute" can´t operate on divs cause the DOM isn´t fully loaded at this point.

how can i ensure, that the "map" route is triggered not until the DOM is fully loaded?


use something more integrated with jquery mobile, for instance jquerymobile-router (you can find it on github). It replaces backbone's router and it's to be used with jquery mobile and backbone.js or spine.js


I figured out that if you dont use "/" in backbone router it will do fine.

e.g.:

use

"category-:id": "category"

instead of this

"category/id/:id": "category"

I guess thats why they used same concept in the official tutorial :P http://jquerymobile.com/test/docs/pages/Backbone-Require/js/routers/mobileRouter.js

"category?:type": "category"


I had the same issue, and here is the solution to avoid using jquerymobile-router : Backbone.js and jQueryMobile routing without hack or other router

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜