Angular设置title信息解决SEO方面存在问题


Posted in Javascript onAugust 19, 2016

Javascript框架在处理seo方面存在问题,因为爬虫在检索seo信息的时候会读不了js给其赋的值,导致搜索引擎收录不了或者收录了无效的信息,比如收录的可能是title={{title}}这样的,下面先说如何在路由跳转时修改页面的seo信息,现在spa跳转一般用route-ui了,就以这个为基础讲解,在app.js配置项state中加入title信息,如下:data:{ pageTitle:'user title'}

.state('index.user', {
url: '/user',
views: {
'content@index': {
templateUrl: 'templateHtml/user/user.html',
controller: 'userCtrl'
}
},
data:{
pageTitle:'user title'
}
})
.state('index.user.a', {
url: '/a',
templateUrl: 'templateHtml/user/a.html',
data:{
pageTitle:'user a title'
}
})
.state('index.user.b', {
url: '/b',
templateUrl: 'templateHtml/user/b.html',
data:{
pageTitle:'user b title'
}
})

然后使用通过监听$stateChangeSuccess来修改页面title:

app.directive('title', ['$rootScope', '$timeout',
function($rootScope, $timeout) {
return {
link: function() {
var listener = function(event, toState) {
console.log(toState);
$timeout(function() {
$rootScope.title = (toState.data && toState.data.pageTitle)
? toState.data.pageTitle
: 'Default title';
$rootScope.metakeywords="this is keywords"
});
};
$rootScope.$on('$stateChangeSuccess', listener);
}
};
}
]);

这里赋值是通过获取当前state中设置的title,也就是这里toState对象的值,当我们打印这个toState时就会发现:

Angular设置title信息解决SEO方面存在问题

这里是获取的已经设置好的data中pageTitle的值,如果不想写在state里或者写死,可以传state中的唯一标示,配合后台接口,将查询的title渲染到页面;同样meta标签如keywords、description可以在此时一同绑定;

上面说到javascript框架在seo方面存在短板,应对ng的这个问题市面上也有很多方案,比如prerender,seo.js等,思想都是在页面加入表示,让爬虫在页面渲染好后才去扒数据,同时服务器上要配置些服务,服务将检测是否有对应这个URL的快照或者缓存的页面,如果存在就发给爬虫,如 果不存在,则生成快照,然后发送正确的页面给爬虫;处理起来还是要费些功夫的,所以也可以采用ng+常规的开发模式,一些重要的页面不要用这种页面渲染seo的方式,或者建立专门的seo信息页;所以在这方面感觉用ng框架做app(ionic)还是很合适的;

以上所述是小编给大家介绍的Angular设置title信息解决SEO方面存在问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript学习随笔(使用window和frame)的技巧
Mar 08 Javascript
Jquery 快速构建可拖曳的购物车DragDrop
Nov 30 Javascript
jquery+ashx无刷新GridView数据显示插件(实现分页、排序、过滤功能)
Apr 25 Javascript
JQuery each()函数如何优化循环DOM结构的性能
Dec 10 Javascript
jquery复选框全选/取消示例
Dec 30 Javascript
JavaScript继承模式粗探
Jan 12 Javascript
jQuery中layer分页器的使用
Mar 13 Javascript
当vue路由变化时,改变导航栏的样式方法
Aug 22 Javascript
element-ui 时间选择器限制范围的实现(随动)
Jan 09 Javascript
在layui中select更改后生效的方法
Sep 05 Javascript
vue中组件通信详解(父子组件, 爷孙组件, 兄弟组件)
Jul 27 Javascript
用JS创建一个录屏功能
Nov 11 Javascript
js仿腾讯QQ的web登陆界面
Aug 19 #Javascript
基于WebUploader的文件上传js插件
Aug 19 #Javascript
JS获取checkbox的个数简单实例
Aug 19 #Javascript
JS提示:Uncaught SyntaxError:Unexpected token ) 错误的解决方法
Aug 19 #Javascript
jQuery搜索框效果实现代码(百度关键词联想)
Feb 25 #Javascript
浅谈js中test()函数在正则中的使用
Aug 19 #Javascript
javascript设计模式Constructor(构造器)模式
Aug 19 #Javascript
You might like
什么是调频(FM)、调幅(AM)、短波(SW)、长波(LW)
2021/03/01 无线电
PHP+Mysql+Ajax+JS实现省市区三级联动
2014/05/23 PHP
详解PHP导入导出CSV文件
2014/11/03 PHP
php限制上传文件类型并保存上传文件的方法
2015/03/13 PHP
PHP7.1方括号数组符号多值复制及指定键值赋值用法分析
2016/09/26 PHP
javascript循环变量注册dom事件 之强大的闭包
2010/09/08 Javascript
document.getElementById介绍
2011/09/13 Javascript
js实现鼠标拖动图片并兼容IE/FF火狐/谷歌等主流浏览器
2013/06/06 Javascript
jQuery实现可关闭固定于底(顶)部的工具条菜单效果
2015/11/06 Javascript
js过滤HTML标签完整实例
2015/11/26 Javascript
jquery实现定时自动轮播特效
2015/12/10 Javascript
深入浅析AngularJS和DataModel
2016/02/16 Javascript
Jquery插件仿百度搜索关键字自动匹配功能
2016/05/11 Javascript
JS函数修改html的元素内容,及修改属性内容的方法
2016/10/28 Javascript
JavaScript制作弹出层效果
2016/12/02 Javascript
JavaScript实现经典排序算法之插入排序
2016/12/28 Javascript
HTML中使背景图片自适应浏览器大小实例详解
2017/04/06 Javascript
以v-model与promise两种方式实现vue弹窗组件
2018/05/21 Javascript
详解小程序云开发数据库
2019/05/20 Javascript
如何使用Javascript中的this关键字
2020/05/28 Javascript
JS+canvas五子棋人机对战实现步骤详解
2020/06/04 Javascript
vue elementui tree 任意级别拖拽功能代码
2020/08/31 Javascript
在Windows8上的搭建Python和Django环境
2014/07/03 Python
在Python3中初学者应会的一些基本的提升效率的小技巧
2015/03/31 Python
Python实现的IP端口扫描工具类示例
2019/02/15 Python
Python使用reportlab模块生成PDF格式的文档
2019/03/11 Python
Pycharm+Python工程,引用子模块的实现
2020/03/09 Python
Python带参数的装饰器运行原理解析
2020/06/09 Python
中国综合网上购物商城:苏宁易购
2016/08/09 全球购物
澳大利亚宠物食品和药物在线:Jumbo Pets
2018/03/24 全球购物
TIME时代杂志台湾总代理:台时亚洲
2018/10/22 全球购物
加拿大在线隐形眼镜和眼镜店:VisionPros
2019/10/06 全球购物
法人代表任命书范本
2014/06/05 职场文书
结婚幸福感言
2015/08/01 职场文书
nginx location优先级的深入讲解
2021/03/31 Servers
Shell中的单中括号和双中括号的用法详解
2022/12/24 Servers