我开始撰写可能成为大型商业网站的内容。该业务有几个方面,因此我正在考虑基于“小部件”的用户界面与BBC主页(http://www.bbc.co.uk)不同。
我正在编写一个内容管理系统,允许管理员使用一系列预定义的小部件(即文本小部件,产品小部件,新闻标题小部件等)来组合页面。我正在使用ASP.NET MVC编写应用程序。
每个窗口小部件类型的标记将封装在用户控件(ascx)中。我正在考虑两种渲染小部件的方法(我可以混合使用):
使用RenderPartial在服务器上构建页面(非常类似于ASP.NET MVC站点中的Kona示例)
在服务页面上呈现小部件占位符,然后让客户端为每个占位符发出请求(使用jquery调用返回HTML的标准MVC操作)。
第二种方法吸引人有两个原因:
它允许返回页面而不必等待缓慢渲染的小部件(可能是评论小部件)。
它允许我控制窗口小部件级别的缓存(而不是页面级别)。我可以使用内置的OutputCache属性来单独控制每种窗口小部件类型的缓存类型。
以下是问题:
如果页面的某些内容仅由javascript启动的HTTP GET请求呈现(即未包含在初始响应中),那么此内容是否会包含在Google的页面评估/索引中?
假设在document.ready
上触发了javascript请求对于喜欢代码的人,我的原型在服务器上使用此代码实现第二种方法:
[OutputCache(Duration = 30, VaryByParam = "widgetUniqueKey")]
public ActionResult RenderWidget(int widgetId)
{
var cmsService = new CmsService();
var widget = cmsService.GetWidget(widgetId);
string viewName = widget.Accept(new ViewNameWidgetVisitor());
object viewData = widget.Accept(new ViewDataWidgetVisitor());
return View(viewName, viewData);
}
在客户端上使用此代码(初始页面GET已返回占位符div)
$('.widgetPlaceholder').each(function() { renderWidget(this) });
function renderWidget(source) {
var placeholder = $(source);
var widgetId = placeholder.attr('id').replace("widget", "");
var widgetUniqueKey = placeholder.children('div.uniqueId').text();
$.get('/home/RenderWidget', {
widgetId: widgetId,
widgetUniqueKey: widgetUniqueKey
},
function(data) {
placeholder.replaceWith(data);
}, "html"
);
}
widgetUniqueKey将在窗口小部件类型之间变化:它可能是产品窗口小部件的产品ID;推荐小部件的用户ID;等
非常感谢
答案 0 :(得分:1)
没有。谷歌机器人(以及我所知的任何其他索引器)不会执行任何javascript代码,因此您通过ajax获取的任何内容都不会被编入索引。