Ô½À´Ô½¶àµÄÍøÕ¾£¬¿ªÊ¼²ÉÓá°µ¥Ò³Ãæ½á¹¹¡±£¨Single-page application£©¡£
Õû¸öÍøÕ¾Ö»ÓÐÒ»ÕÅÍøÒ³£¬²ÉÓÃAjax¼¼Êõ£¬¸ù¾ÝÓû§µÄÊäÈ룬¼ÓÔØ²»Í¬µÄÄÚÈÝ¡£
ÕâÖÖ×ö·¨µÄºÃ´¦ÊÇÓû§ÌåÑéºÃ¡¢½ÚÊ¡Á÷Á¿£¬È±µãÊÇAJAXÄÚÈÝÎÞ·¨±»ËÑË÷ÒýÇæ×¥È¡¡£¾ÙÀýÀ´Ëµ£¬ÄãÓÐÒ»¸öÍøÕ¾¡£
| 1 |
http://example.com
|

Óû§Í¨¹ý¾®ºÅ½á¹¹µÄURL£¬¿´µ½²»Í¬µÄÄÚÈÝ¡£
| 1 2 3 |
http://example.com#1
http://example.com#2
http://example.com#3
|
µ«ÊÇ£¬ËÑË÷ÒýÇæÖ»×¥È¡example.com£¬²»»áÀí»á¾®ºÅ£¬Òò´ËÒ²¾ÍÎÞ·¨Ë÷ÒýÄÚÈÝ¡£
ΪÁ˽â¾öÕâ¸öÎÊÌ⣬GoogleÌá³öÁË¡±¾®ºÅ+¸Ð̾ºÅ¡±µÄ½á¹¹¡£
| 1 |
http://example.com#!1
|
µ±Google·¢ÏÖÉÏÃæÕâÑùµÄURL£¬¾Í×Ô¶¯×¥È¡ÁíÒ»¸öÍøÖ·£º
| 1 |
http://example.com/?_escaped_fragment_=1
|
Ö»ÒªÄã°ÑAJAXÄÚÈÝ·ÅÔÚÕâ¸öÍøÖ·£¬Google¾Í»áÊÕ¼¡£µ«ÊÇÎÊÌâÊÇ£¬¡±¾®ºÅ+¸Ð̾ºÅ¡±·Ç³£ÄÑ¿´ÇÒ·³Ëö¡£TwitterÔø¾²ÉÓÃÕâÖֽṹ£¬Ëü°Ñ
| 1 |
http://twitter.com/ruanyf
|
¸Ä³É
| 1 |
http://twitter.com/#!/ruanyf
|
½á¹ûÓû§±§Ô¹Á¬Á¬£¬Ö»ÓÃÁ˰ëÄê¾Í·Ï³ýÁË¡£
ÄÇô£¬ÓÐûÓÐʲô·½·¨£¬¿ÉÒÔÔÚ±£³Ö±È½ÏÖ±¹ÛµÄURLµÄͬʱ£¬»¹ÈÃËÑË÷ÒýÇæÄܹ»×¥È¡AJAXÄÚÈÝ£¿
ÎÒÒ»Ö±ÒÔΪûÓа취×öµ½£¬Ö±µ½Ç°Á½Ìì¿´µ½ÁËDiscourse´´Ê¼ÈËÖ®Ò»µÄRobin WardµÄ½â¾ö·½·¨£¬²»½ûÅݸ½Ð¾ø¡£

DiscourseÊÇÒ»¸öÂÛ̳³ÌÐò£¬ÑÏÖØÒÀÀµAjax£¬µ«ÊÇÓÖ±ØÐëÈÃGoogleÊÕ¼ÄÚÈÝ¡£ËüµÄ½â¾ö·½·¨¾ÍÊÇ·ÅÆú¾®ºÅ½á¹¹£¬²ÉÓà History API¡£
Ëùν History API£¬Ö¸µÄÊDz»Ë¢ÐÂÒ³ÃæµÄÇé¿öÏ£¬¸Ä±ää¯ÀÀÆ÷µØÖ·À¸ÏÔʾµÄURL(׼ȷ˵£¬ÊǸıäÍøÒ³µÄµ±Ç°×´Ì¬)¡£ÕâÀïÓÐÒ»¸öÀý×Ó£¬Äãµã»÷ÉÏ·½µÄ°´Å¥£¬¿ªÊ¼²¥·ÅÒôÀÖ¡£È»ºó£¬ÔÙµã»÷ÏÂÃæµÄÁ´½Ó£¬¿´¿´·¢ÉúÁËʲôÊ£¿

µØÖ·À¸µÄURL±äÁË£¬µ«ÊÇÒôÀÖ²¥·ÅûÓÐÖжϣ¡
History API µÄÏêϸ½éÉÜ£¬³¬³öÕâÆªÎÄÕµķ¶Î§¡£ÕâÀïÖ»¼òµ¥Ëµ£¬ËüµÄ×÷ÓþÍÊÇÔÚä¯ÀÀÆ÷µÄHistory¶ÔÏóÖУ¬Ìí¼ÓÒ»Ìõ¼Ç¼¡£
| 1 |
window.history.pushState(state object, title, url);
|
ÉÏÃæÕâÐÐÃüÁ¿ÉÒÔÈõØÖ·À¸³öÏÖеÄURL¡£History¶ÔÏóµÄpushState·½·¨½ÓÊÜÈý¸ö²ÎÊý£¬ÐµÄURL¾ÍÊǵÚÈý¸ö²ÎÊý£¬Ç°Á½¸ö²ÎÊý¶¼¿ÉÒÔÊÇnull¡£
| 1 |
window.history.pushState(null, null, newURL);
|
Ŀǰ£¬¸÷´óä¯ÀÀÆ÷¶¼Ö§³ÖÕâ¸ö·½·¨£ºChrome£¨26.0+£©£¬Firefox£¨20.0+£©£¬IE£¨10.0+£©£¬Safari£¨5.1+£©£¬Opera£¨12.1+£©¡£
ÏÂÃæ¾ÍÊÇRobin WardµÄ·½·¨¡£
Ê×ÏÈ£¬ÓÃHistory APIÌæ´ú¾®ºÅ½á¹¹£¬ÈÃÿ¸ö¾®ºÅ¶¼±ä³ÉÕý³£Â·¾¶µÄURL£¬ÕâÑùËÑË÷ÒýÇæ¾Í»áץȡÿһ¸öÍøÒ³¡£
| 1 2 3 |
example.com/1
example.com/2
example.com/3
|
È»ºó£¬¶¨ÒåÒ»¸öJavaScriptº¯Êý£¬´¦ÀíAjax²¿·Ö£¬¸ù¾ÝÍøÖ·×¥È¡ÄÚÈÝ£¨¼Ù¶¨Ê¹ÓÃjQuery£©¡£
| 1 2 3 4 5 6 |
¡¡function anchorClick(link) {
¡¡¡¡var linkSplit=link.split('/').pop();
¡¡¡¡$.get('api/' + linkSplit, function(data) {
¡¡¡¡¡¡¡¡$('#content').html(data);
¡¡¡¡});
}
|
ÔÙ¶¨ÒåÊó±êµÄclickʼþ¡£
| 1 2 3 4 5 |
¡¡$('#container').on('click', 'a', function(e) {
¡¡¡¡window.history.pushState(null, null, $(this).attr('href'));
¡¡¡¡anchorClick($(this).attr('href'));
¡¡¡¡e.preventDefault();
});
|
»¹Òª¿¼Âǵ½Óû§µã»÷ä¯ÀÀÆ÷µÄ¡±Ç°½ø / ºóÍË¡±°´Å¥¡£Õâʱ»á´¥·¢History¶ÔÏóµÄpopstateʼþ¡£
| 1 2 3 |
¡¡window.addEventListener('popstate', function(e) {
¡¡¡¡anchorClick(location.pathname);
});
|
¶¨ÒåÍêÉÏÃæÈý¶Î´úÂ룬¾ÍÄÜÔÚ²»Ë¢ÐÂÒ³ÃæµÄÇé¿öÏ£¬ÏÔʾÕý³£Â·¾¶URLºÍAJAXÄÚÈÝ¡£
×îºó£¬ÉèÖ÷þÎñÆ÷¶Ë¡£
ÒòΪ²»Ê¹Óþ®ºÅ½á¹¹£¬Ã¿¸öURL¶¼ÊÇÒ»¸ö²»Í¬µÄÇëÇó¡£ËùÒÔ£¬ÒªÇó·þÎñÆ÷¶Ë¶ÔËùÓÐÕâЩÇëÇ󣬶¼·µ»ØÈçϽṹµÄÍøÒ³£¬·ÀÖ¹³öÏÖ404´íÎó¡£
| 1 2 3 4 5 6 7 8 |
¡¡<html>
¡¡¡¡<body>
¡¡¡¡¡¡¡¡<section id='container'>section>
¡¡¡¡¡¡¡¡<noscript>
¡¡¡¡¡¡¡¡¡¡¡¡... ...
¡¡¡¡¡¡¡¡noscript>
¡¡¡¡body>
html>
|
×Ðϸ¿´ÉÏÃæÕâ¶Î´úÂ룬Äã»á·¢ÏÖÓÐÒ»¸önoscript±êÇ©£¬Õâ¾ÍÊǰÂÃîËùÔÚ¡£
ÎÒÃǰÑËùÓÐÒªÈÃËÑË÷ÒýÇæÊÕ¼µÄÄÚÈÝ£¬¶¼·ÅÔÚnoscript±êǩ֮ÖС£ÕâÑùµÄ»°£¬Óû§ÒÀÈ»¿ÉÒÔÖ´ÐÐAJAX²Ù×÷£¬²»ÓÃË¢ÐÂÒ³Ãæ£¬µ«ÊÇËÑË÷ÒýÇæ»áÊÕ¼ÿ¸öÍøÒ³µÄÖ÷ÒªÄÚÈÝ£¡
- ÄÚÈÝΪÖ÷ÓÅ»¯Îª¸¨ÈçºÎÁôסÄãµÄÓû§-ÍøÕ¾ÔËÓª
- 15ÖÖÈÃÓû§ÌåÑ鲻ˬµÄÍøÕ¾ÀàÐÍ-ÍøÕ¾ÔËÓª
- ÂäÎéÕß´´Ê¼È˶Çڷ棺µØ·½ÂÛ̳ÔËÓª¸É»õ·ÖÏí-ÍøÕ¾
- seoÓÅ»¯ÖØÔÚÄÚÈÝÓªÏú-ÍøÕ¾ÔËÓª
- ·ÖÏíÖ°ÒµÍø±àµÄÄÚÈÝÀ´Ô´Ñ°ÕÒ·½·¨-ÍøÕ¾ÔËÓª
- ÈçºÎÈÃÄúµÄÍøÕ¾×ß³ö¹È¸è½ûÇø£¿-ÍøÕ¾ÔËÓª
- »ùÓÚKNNµÄÏà¹ØÄÚÈÝÍÆ¼ö-ÍøÕ¾ÔËÓª
- ²Ý¸ùÕ¾³¤ÈçºÎÔËÓª×Ô¼ºµÄÍøÕ¾-ÍøÕ¾ÔËÓª
- һλ×ÊÉîÒ½ÁÆÖ÷±àÑÛÖеÄרÌâÒ³-ÍøÕ¾ÔËÓª
- һλÐÂÊÖSEO´ÓÒµÕßµÄÐÄÉù ÄÚÈÝ»òÒѲ»ÔÙΪÍõ-ÍøÕ¾
- ÆÀÂÛÁÐ±í£¨ÍøÓÑÆÀÂÛ½ö¹©ÍøÓѱí´ï¸öÈË¿´·¨£¬²¢²»±íÃ÷±¾Õ¾Í¬ÒâÆä¹Ûµã»ò֤ʵÆäÃèÊö£©
-
