views:

199

answers:

3

I have an AJAX form that submits GET requests. Because these are all GET requests these should be easily bookmark-able. Preferably I'd make my Ajax request, update the screen and then update window.location.href to be the URL for the new page.

Unfortunately this reloads the page. Is there any way I can get around this? Basically I'd like the URL bar to be a permalink bar, but it needs to be able to change to keep up with the state of the page.

window.location.hash is no good because that doesn't get sent to the server.

A: 

Use jquery. It can do ajax requests. You cant use window.location because that is made to change the url.

NebNeb
+1  A: 

if you want to do which works in current browser, you can't change window.location.href without reloading the page

your only option is to to change window.location.hash.

you can do that each time you make an ajax call. if you're using jquery, you can bind a function which update the hash each time an ajax call is made. if you choose that you'll have to look for the hash on page load (actually don't know/think you can do that server side) and make that call to have your page on the state corresponding to the hash.

mathroc
+1  A: 

The hash is the way to go. Because, as you point out, changes to the hash don't get sent to the server, you have to send an async request to the server as well as updating the hash.

As a simple example, if your URL is http://server.com/page?id=4, when the user triggers the action you send an AJAX request for http://server.com/page?id=4, and set the page URL to http://server.com/page#id=4.

Furthermore, you have to have something to restore the state if the user reloads. This would usually be done by reading the hash value client-side and sending an async request to the server based on the state represented by the hash value.

jhurshman
Well, it makes me sad but I guess there's no way around this. Am I crazy or does it seem like I should be able to say "Hey browser, I updated the page and I'd like you to reflect that. And next time you come here, how about I just serve you that new resource." and the browser says "Let's not. How about you serve me a page that I will then process so that you it makes a second request to get the page you wanted in the first place." "Allright man, it's your world."
jdwyah
I think HTML5's History feature may provide this, but it will be a long time before it's commonly available.http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#history
jhurshman
awesome. looks like window.history.replaceState is what I want. that and a browser that implements it :(
jdwyah