Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 9075041
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 16, 20262026-06-16T18:46:35+00:00 2026-06-16T18:46:35+00:00

I have been working on a project that uses Backbone.js router and all data

  • 0

I have been working on a project that uses Backbone.js router and all data is loaded by javascript via restful requests. I know that there is no way to detect whether Javascript is enabled or not in server-side but here is the scenarios that I thought to make this website indexable:

  1. I can append a query string for each link on sitemap.xml and I can put a <script> tag to detect whether Javascript is enabled or not. The server renders this page with indexable data and when a user visits this page I can manually initialize Backbone.js router. However the problem is I need to execute an sql query to render indexable data in server-side and it will cause an extra load if the visitor is not a bot. And when users share an url of the website somewhere, it won’t be an indexable page and web crawlers may not identify the content of that url. And an extra string in web crawler’s search page may be annoying for users.

  2. I can detect popular web crawlers like Google, Yahoo, Bing, Facebook in server-side from their user-agents but I suspect that there will be some web crawlers that I missed.

Which way seems more convenient or do you have any idea & experience to make indexable this kind of websites?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-16T18:46:37+00:00Added an answer on June 16, 2026 at 6:46 pm

    As elias94xx suggested in his comment, one solid solution to this dilemma is to take advantage of Google’s “AJAX crawling”. In short Google told the web community “look we’re not going to actually render your JS code for you, but if you want to render it server-side for us, we’ll do our best to make it easy on you.” They do that with two basic concepts: pretty URL => ugly URL translation and HTML snapshots.

    1) Google implemented a syntax web developers could use to specify client-side URLs that could still be crawled. This syntax for these “pretty URLs”, as Google calls them, is: www.example.com?myquery#!key1=value1&key2=value2.

    When you use a URL with that with that format, Google won’t try to crawl that exact URL. Instead, it will crawl the “ugly URL” equivalent: www.example.com?myquery&_escaped_fragment_=key1=value1%26key2=value2. Since that URL has a ? instead of a # this will of course result in a call to your server. Your server can then use the “HTML snapshot” technique.

    2) The basics of that technique is that you have your web-server run a headless JS runner. When Google requests an “ugly URL” from your server, the server loads up your Backbone router code in the headless runner, and it generates (and then returns to Google) the same HTML that code would have generated had it been run client-side.

    A full explanation of pretty=>ugly URLs can be found here:
    https://developers.google.com/webmasters/ajax-crawling/docs/specification

    A full explanation of HTML snapshots can be found here:
    https://developers.google.com/webmasters/ajax-crawling/docs/html-snapshot

    Oh, and while everything so far has been based on Google, Bing/Yahoo also adopted this syntax, as indicated by Squidoo here:
    http://www.squidoo.com/ajax-crawling

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm working on an iPad project that uses a third-party SDK, and have been
I have an XCode 4.2 project that I've been working with all day just
I have been working on a C++ project that uses SDL, and wonder if
So recently I have been working on phonebook project that uses Binary Search Tree.
I am working on my first large project that uses EF4 and have been
I have been working in a C++ project that uses doxygen to generate documentation
Hey so I have been working on a project that I want to be
I have a django project that I have been working on as a solo
I have a console project that I have been working on. I added log4net
I have a project on github that I have been working on before. However,

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.