Note that there are some explanatory texts on larger screens.

plurals
  1. PO
    text
    copied!<p>First of all: I'm the author of the The Single Page Interface Manifesto cited by raganwald </p> <p>As raganwald has explained very well, the most important aspect of the Single Page Interface (SPI) approach used in FaceBook and Twitter is the use of hash <code>#</code> in URLs</p> <p>The character <code>!</code> is added only for Google purposes, this notation is a Google "standard" for crawling web sites intensive on AJAX (in the extreme Single Page Interface web sites). When Google's crawler finds an URL with <code>#!</code> it knows that an alternative conventional URL exists providing the same page "state" but in this case on load time. </p> <p>In spite of <code>#!</code> combination is very interesting for SEO, is only supported by Google (as far I know), with some JavaScript tricks you can build SPI web sites SEO compatible for any web crawler (Yahoo, Bing...).</p> <p>The SPI Manifesto and demos do not use Google's format of <code>!</code> in hashes, this notation could be easily added and SPI crawling could be even easier (UPDATE: now ! notation is used and remains compatible with other search engines).</p> <p>Take a look to this <a href="http://itsnat.sourceforge.net/index.php?_page=support.tutorial.spi_site" rel="noreferrer">tutorial</a>, is an example of a simple ItsNat SPI site but you can pick some ideas for other frameworks, this example is SEO compatible for any web crawler. </p> <p>The hard problem is to generate any (or selected) "AJAX page state" as plain HTML for SEO, in ItsNat is very easy and automatic, the same site is in the same time SPI or page based for SEO (or when JavaScript is disabled for accessibility). With other web frameworks you can ever follow the double site approach, one site is SPI based and another page based for SEO, for instance Twitter uses this "double site" technique. </p>
 

Querying!

 
Guidance

SQuiL has stopped working due to an internal error.

If you are curious you may find further information in the browser console, which is accessible through the devtools (F12).

Reload