- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直在构建一个无需重新加载(使用 PHP 和 AJAX)的基于 jquery 导航的站点,并且最近遇到了页面“后退”、“前进”和“重新加载”功能以及 SEO 友好性的问题。
--跳过这部分直接进入问题--
my site目前(不使用 AJAX,但)加载一个 index.php,它有几个“内容”div,其中一个是可见的(class="active"),而其他的则不显示。当用户单击导航链接时,一个漂亮的动画会在内容 div 之间切换。
我重写了 apache 来映射类似的东西
http://mysite.com/about
到 http://mysite.com/index.php?page=about
其中“关于”部分是默认显示的部分(而其他“内容”div 是隐藏的)。基于此参数,我为页面添加了适当的元标记。我的站点地图有 mysite.com/about、mysite.com/blog,这样它们就可以作为单独的页面被编入索引。
但是,我最近决定让这个基于 ajax,因为我计划合并更多的内容,而且将所有内容加载到一个页面上是愚蠢的。
注意:我现在也在实现 Smarty 模板。
我决定实现散列标签,但看到了固有的 SEO 问题,然后我发现了 hashbangs(wth?!),然后发现了带有 history.pushState() 和 的新 HTML5 内容History.js 并决定使用它。
那么主要问题来了
如果我只有一个页面使用 ajax 在内容 div 中加载页面模板,使用 history.pushState() 修改 URL 并使用 mod_rewrite 和一个 PHP 后端,它可以在以下情况下提供默认内容模板像“mysite.com/about”这样的直接请求(mysite.com/index.php?page=about)(用于基本可用性和 SEO),我也不能为直接请求设置元内容,除非我有两个模板 - 一个内容模板 -和元模板?还有其他解决方法吗?
是像<title>
这样的标签和 <meta name="description">
重要到足以保证有一个特别适合他们的模板?
总而言之,我希望我漂亮的 mod_rewrite URLS 能够在 google 上显示特定加载 ajax 的页面内容模板的正确标题和元描述。
编辑
我正在做与他们在 hypem.com 上进行的几乎相同的事情.他们有一个事件监听器可以更改 <title>
列出新内容时标记。他们还提供正确的 <meta name="description">
标签,但前提是它是对主要页面之一的直接请求,例如博客 - 其他页面,例如 http://hypem.com/blog/indie+today/10332 , 返回主要博客页面的元标记,并且仅在直接请求时返回
最佳答案
我会首先构建站点以使用所有直接链接而不使用 ajax,然后添加 ajax。但是,如果浏览器正在请求页面,则只包含添加 ajax/历史功能的代码。如果网络爬虫访问您的站点,请不要包含 ajax/历史记录功能。
关于php - history.pushState 导航 - 元标签怎么样 - 单独的模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7261373/
所以基本上我正在开发一个 Ionic/React Typescript 应用程序,当我导航到应用程序时,这个奇怪的页面转换发生了两次(见下面的 gif) 我检查了一下,不是渲染调用了两次,因为 com
我正在开发一个 ember 应用程序(使用 ember-1.0.pre.js)。我正在尝试在 IE8 上提供跨浏览器兼容性。 问题在于每次转换后都会生成 url,这对用户来说似乎不正确/错误。假设我点
使用 pry 插件:pry-clipboard 当我输入“copy-history”来复制我历史的最后一行时,它实际上是在复制“copy-history”并粘贴“copy-history”。 我是不是
我正在开发一个我想使用的 React 应用程序 @types/history模块.. 已安装 npm install --save @types/history 在我的组件文件中尝试导入 import
我刚刚在 Google Chrome 中打开了一个带有少量基本标签(如 html、body、head 等)的空白 HTML 页面,并尝试在控制台中执行以下命令: history.pushState(n
我在我的网络浏览器中调用了一些 javascript。目的是获取 history.length,如果长度 == 0,则在按下后退键时退出应用程序。 所以我使用了 window.external.not
具体来说,调用下面的代码片段: history.replaceState(undefined, undefined, "#" + value) 不会正确地影响当前页面的后退按钮行为,但会向“浏览历史”
为什么我要使用 react-router-dom 中的路由器历史记录而不是 window.history.back()? 有没有一种方法可以检测用户是否来 self 的应用程序中的某个页面或来自特定外
我为 angular.js 中内置的 phonegap 应用程序设置了一些后退/下一步按钮。 我正在为页面使用 Angular 部分,并使用 window.history 作为一些简单的后退/下一步按
我正在通过 Ajax 加载页面。当用户单击链接时,页面已成功加载 AJAX,但当用户单击后退按钮时,页面会重新加载初始页面。所以场景是这样的。 载入初始页面(index.php) 用户点击链接 页面加
这个问题在这里已经有了答案: How to get notified about changes of the history via history.pushState? (16 个答案) 关闭
History API使得在浏览器历史记录中存储状态对象成为可能。现在试试 this demo (但它与其他任何行为相同,请选择您最喜欢的 :)): 点击一些链接建立一些历史 清除您的浏览器历史记录(
我正在开发一个网站,我需要返回到我访问过的页面。我正在使用parent.history.back。我的一位 friend 建议使用 window.history.back 而不是 Parent.his
几年前,我的一个 Perforce depot 中的一个子文件夹(例如 //FirstDepot/LargeSubfolder/...)变得太大而无法维护,所以我将它“迁移”到一个它自己的仓库(例如
到目前为止,我已经阅读了很多有关 React-router v4 和 npm 历史库的内容,但似乎没有一个对我有帮助。 我的代码按预期运行,当使用 History.push() 方法更改 url 时,
我正在通过phonegap做移动html页面我想将用户重定向到首页。所以我无法给出直接链接,例如指向index.html的href 当用户单击 Logo 时,我想计算他访问的页面长度并使用 histo
使用 django-simple-history ,如何从我的模型中获取最后更改的对象? 我尝试了 MyModel.history.most_recent(),它需要一个模型实例,因此可能会返回所选实
过去,如果我不确定某些内容是否受支持, 我将在 Javascript 中输入 If(something){ ... }。 最近我发现Modernizr也很容易检测浏览器的支持。 它将向 HTML 添加
我尝试在应用程序中使用 history.replace('/user') 重定向用户,但是当我这样做时,它什么也没做。我正在使用 Auth0 并遵循他们的指南: https://auth0.com/d
model.compile(loss='categorical_crossentropy', optimizer=keras.optimizers.Adam(), metrics=['accuracy
我是一名优秀的程序员,十分优秀!