去哈希邦还是不去哈希邦?

发布于 2024-11-24 20:32:39 字数 963 浏览 5 评论 0原文

我正在开发一个新网站,我想尽可能地利用 AJAX。基本上,我希望用户几乎永远不会离开主页,并在弹出窗口、滑块、部分等中显示所有内容。

现在我们现有的网站已经排名很高,所以我也想让谷歌满意。我一直在阅读 Google 的使 AJAX 应用程序可抓取,并且了解我必须通过 _escaped_fragment_ 为抓取工具提供相同的内容。

问题
我想使用 Umbraco 开发这个网站,它已经提供了 SEO 友好的 URL。 ie

但问题是我没有一个简单的方法实现_escaped_fragment_而不破解Umbraco核心(至少这是我的知识),并且使用我在下面发布的解决方案(答案)也将使没有Javascript的用户感到满意。双赢?你告诉我吧! =)

更新
昨天有另一位用户的回答(现已删除),他建议 Google 不再使用 _escaped_fragment_ 方法,并建议忽略此方法。这是真的吗? Google 真的会运行 AJAX 来查看内容吗?

谢谢
马尔科

I'm developing a new website and I'd like to make use of AJAX as much as possible. Basically, I want users to almost never navigate away from the homepage and have everything displaying in popup windows, sliders, sections etc.

Now our existing website already ranks pretty high so I also want to keep Google happy. I've been reading the Making AJAX Applications Crawlable by Google and understand that I have to provide the same content for the crawler via _escaped_fragment_.

The problem
I want to develop this website using Umbraco which already provides SEO-friendly URLs. i.e.

But the issue is that I don't have an easy way of implemeting _escaped_fragment_ without hacking the Umbraco core (at least that's my knowledge), and using the solution(answer) I have posted below will also keep users without Javascript happy. Win-Win situation? You tell me! =)

Update
There was an answer from another user yesterday (now deleted) who suggested that Google no longer uses the _escaped_fragment_ method and suggested this be left out. Is this true? Will Google actually run the AJAX to see the content?

Thanks
Marko

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

暮凉 2024-12-01 20:32:39

我采纳了 @Daniel Pryden 评论中的建议,并将其作为答案发布。

我思考过这个问题并想 - 为什么不以老式方式创建网站、实际页面和所有内容,然后执行以下步骤。

  1. 使用 jQuery 拦截主页上的所有内部链接,并在 window.location.pathname 前面添加井号 (#),从而触发 hashchange 事件。 (请参阅步骤 3)
  2. 在除主页之外的所有页面上添加 javascript 重定向,以将页面重定向回主页,但在哈希 (#) 后附加 window.location.pathname。例如,Google 抓取 http://www.domain.com/about-us.aspx 但是当用户访问该页面时,他们会被重定向到 http://www.domain .com/#/about-us.aspx
  3. 在主页上,使用 jQuery BBQ 或类似的插件来侦听 hashchange 事件,包括页面加载时间,以便可以加载动态内容。 Umbraco 可以配置为根据请求是否是 AJAX 请求来提供部分或完整页面内容。

这样,没有 Javascript 的用户将拥有一个成熟的(半好看的)网站,Google 将毫无问题地抓取所有页面,但使用 Javascript 的用户将始终停留在主页上 - 以及拥有一个很酷的概念将完成 Web 应用程序而不是网站。

I'm taking the advice from @Daniel Pryden's comment and posting this as an answer instead.

I had a think about this problem and thought - why not create the website in an old fashioned manner, actual pages and everything but then perform the following steps.

  1. Intercept all internal links on the homepage using jQuery and prepend a hash (#) before the window.location.pathname, thus triggering the hashchange event. (see step 3)
  2. Add a javascript redirect on all pages apart from the homepage to redirect pages back to the homepage, but append the window.location.pathname after a hash (#). For example, Google crawls http://www.domain.com/about-us.aspx but when a user visits the page, they're redirected to http://www.domain.com/#/about-us.aspx
  3. On the homepage, use jQuery BBQ or a similar plugin to listen for the hashchange event including when the page loads so that dynamic content can be loaded. Umbraco can be configured to serve partial or full page content based on whether the request is an AJAX one or not.

This way, users without Javascript will have a full-blown (semi-good-looking) website, Google will crawl all of the pages without any issues, but users with Javascript will always stay on the homepage - and the cool concept of having a Web App rather than a Web Site will be accomplished.

仅一夜美梦 2024-12-01 20:32:39

您是否也考虑过使用 HTML5 历史会话管理?

这样您就不必在较新的浏览器中使用哈希值,这样用户就不会注意到一件事。

有点简单,你会做这样的事情:

编辑:更新的例子。

function route(path) {
    $.get(path, function(data) {
        //parse data
    });
}

if (typeof history.pushState !== 'undefined') 
{
    $(window).bind('popstate', function(e)
    {
        route(window.location.pathname);
    });
    $('a').click(function(event) {
        event.preventDefault();
        history.pushState({},'',this.href);
    });
} else {
    $(window).bind('hashchange', function(e)
    {
        route(window.location.hash);
    });
    $('a').click(function(event) {
        event.preventDefault();
        $(this).attr('href', '/#'+$(this).attr('href'));
    });
}

Have you also considered to use the HTML5 history session management?

This way you don't have to use hashes in newer browsers and that way the user won't notice a thing.

A bit simplified you would do something like this:

EDIT: updated example.

function route(path) {
    $.get(path, function(data) {
        //parse data
    });
}

if (typeof history.pushState !== 'undefined') 
{
    $(window).bind('popstate', function(e)
    {
        route(window.location.pathname);
    });
    $('a').click(function(event) {
        event.preventDefault();
        history.pushState({},'',this.href);
    });
} else {
    $(window).bind('hashchange', function(e)
    {
        route(window.location.hash);
    });
    $('a').click(function(event) {
        event.preventDefault();
        $(this).attr('href', '/#'+$(this).attr('href'));
    });
}
青丝拂面 2024-12-01 20:32:39

使用 jQuery BBQ 并使用页面顶部的 js 函数来检查是否存在有效的哈希值,如果存在,则重定向到该页面。

Use jQuery BBQ and use a js function at the top of your pages to check if there is a valid hash, if so, redirect to the page.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文