That mostly makes sense to me.
The part I'm still confused about is 1.2.
I'm able to make the server redirect to */#/v2/challenges/new* for IE9, but
how will Angular know to do the same thing at */#/v2/challenges/new* and
*/v2/challenges/new* (no hashbang)?
In other words, I load */v2/challenges/new* in Chrome and serve the index
route, which has all my Angular routes set up. One of those routes is:
$routeProvider
.when('/v2/challenges/new', {
templateUrl: '/assets/templates/new.html',
controller: 'BuildController'
... so Angular correctly loads the correct controller and template.
But if I load* /v2/challenges/new* in IE9, and then I configure Rails to
redirect to* /#/v2/challenges/new, *what should happen then? I realize that
answer is probably fairly specific to my app, but maybe there's a general
answer.
Again, I really appreciate your help so far. This is super confusing to me.
(Sorry for the odd delay; had to step away from this problem for a few days)
On Thursday, April 24, 2014 12:36:16 PM UTC-7, Alesei N wrote:
>
> I think this should make it bit more clear:
> 1) User enters site at /v2/challenges/new
> 1.1) default: browser that supports html5 history would then serve
> index view from that route, index view has all the references to JS/CSS.
> Angular app loads, sees its at /v2/challenges/new and does what it needs
> to do for that route.
> 1.2) user agent is ie9: you would have to redirect them to root of
> domain.com plus appending this route to it via hash bang
> domain.com/#/v2/challenges/new.
> So at the end you actually redirecting to domain.com/#/v2/challenges/new.
>
>
>
>
>
>
>
>
>
>
> On Thu, Apr 24, 2014 at 11:15 AM, Yale Kaul <[email protected]<javascript:>
> > wrote:
>
>> Thanks so much for your reply, Alesei.
>>
>> So if I'm understanding you correctly, the flow for an IE9 visitor is
>> this:
>>
>> 1. User loads /v2/challenges/new,
>> 2. Angular rewrites to /#!/v2/challenges/new
>> 3. Browser ignores everything after #, and loads '/'
>> 4. Server serves up '/', which must have references to Angular scripts
>> --
>> 5. This is the part I'm still not understanding. Once I get to the root
>> route, the Angular router takes over? How does it differentiate between
>> someone requesting /#!/v2/challenges/new and someone requesting root
>> route?
>>
>> Thanks again!
>>
>>
>> On Thursday, April 24, 2014 6:02:36 AM UTC-7, Alesei N wrote:
>>>
>>> it means, all the routes that you have set up in your SPA, should have
>>> corresponding Rails routes. So when you are hitting that route directly in
>>> browser, your rails app can serve html that has references to your angular
>>> app javascript and styles.
>>>
>>> In case of hash bang and ie9 it depends how far you want to go, your
>>> root route, should serve mark up that has references to javascript and
>>> styles, so once app loads it can react to /#!/v2/challenges/new. There
>>> are other things you can do, for example if some one comes from normal url
>>> from search, but user agent is ie9, you could redirect to root with hash
>>> bang equivalent of that route.
>>>
>>>
>>> On Wednesday, April 23, 2014 3:54:44 PM UTC-5, Yale Kaul wrote:
>>>>
>>>> I've been working on an AngularJS/Rails app that must support IE9. From
>>>> what I've read, I should set html5Mode to true in my AngularJS config,
>>>> which will use the HTML5 History API for browsers that support it, and
>>>> fall
>>>> back to hashbang URLs for older browsers. All of the Angular stuff in my
>>>> app is rooted at */v2/challenges/.*
>>>>
>>>> In the fantastic ng-book <https://www.ng-book.com/>, it says:
>>>>
>>>> "The back-end server will have to support URL rewriting on the server
>>>> side. To support HTML5 mode, the server will have to make sure to deliver
>>>> the index.html page for all apps. That ensures that our Angular app will
>>>> handle the route."
>>>>
>>>> What does that mean specifically?
>>>>
>>>> If my AngularJS content is at /v2/challenges/new (which appears as
>>>> /#!/v2/challenges/new in IE9),
>>>>
>>>> ...what does that mean for me in terms of the URL rewriting I need to
>>>> do on the server side?
>>>>
>>>>
>>>> Thanks!
>>>>
>>> --
>> You received this message because you are subscribed to a topic in the
>> Google Groups "AngularJS" group.
>> To unsubscribe from this topic, visit
>> https://groups.google.com/d/topic/angular/0cFJSAi68xw/unsubscribe.
>> To unsubscribe from this group and all its topics, send an email to
>> [email protected] <javascript:>.
>> To post to this group, send email to [email protected]<javascript:>
>> .
>> Visit this group at http://groups.google.com/group/angular.
>> For more options, visit https://groups.google.com/d/optout.
>>
>
>
--
You received this message because you are subscribed to the Google Groups
"AngularJS" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
Visit this group at http://groups.google.com/group/angular.
For more options, visit https://groups.google.com/d/optout.