1、知乎专栏使用angular是怎么做到seo的
个专业的seo人员少不得常常跟搜索引擎网站交道,在搜索框里边查问和寻觅物品,还是查问名次,还是研讨和剖析对手,又还是寻觅资源等等,
2、AngularJS怎么做SEO
J
3、angular,react,vue如何做SEO
百度在变,谷歌在变,搜索引擎都在变。在不断的变化中,我们如何对我们网站进行优化呢?
首先,谈谈新手以及老手在认知上容易出现的SEO误区,我认为有以下几点因素,不容忽视。
1、以为网站首页关键词出现得越多越好,其实不然。
网站首页如果出现大量关键词,大量的关键词堆积在首页,不仅对优化有影响,还会降低用户体验度,我们应把关键词通过长尾关键词的方式展现出来,这不仅不会影响用户体验,还能使流量来得更加定向。
2、以为网站有更新就好。
以为保持每天的网站内容更新就好,可是却随意的copy其他地方的文章,一点原创性都没有,不是原创文章,宁愿不发。
3、认为外链很重要。
认为不断的发外链很重要,不少人认为做SEO就是为了排名,完全不考虑网站文章的质量、可读性以及用户体验,甚至不惜使用一些软件、站群,这样做,即使排名上去了,也无法留住客户。为了做SEO拼命地发外链,完全不考虑外链的质量,认为只要量上去了,排名就会上去,其实不然,这样做会被搜索引擎认定为作弊,会有降权的风险。
4、如何解决 angularjs 异步的问题
如果用AngularJs在IE下发出GET请求从后台服务取完Json数据再绑定到页面上显示的话,你可能会发现就算数据更新了,IE还是会显示原来的结果。实际上这时候IE的确是缓存了hashtag,没有再次去做Http GET请求最新的数据。
最直接的办法是在后台撸掉OutputCache,但这种做法并不推荐,需要改每一处被Angular调用的地方,代价太大。这种问题应该在前端解决最好。研究了一会儿总结了最有效的解决方法,并不需要改后台代码了。
在你的app config里撸一个$httpProvider进去,比如像我这样,和路由可以配在一起,当然分开配也没问题。
var config = ["$routeProvider", "$httpProvider", function ($routeProvider, $httpProvider) {
// Initialize get if not there
if (!$httpProvider.defaults.headers.get) {
$httpProvider.defaults.headers.get = {};
}
// Enables Request.IsAjaxRequest() in ASP.NET MVC
$httpProvider.defaults.headers.common["X-Requested-With"] = 'XMLHttpRequest';
// Disable IE ajax request caching
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
$routeProvider.when("/", { templateUrl: "Manage/dashboard/index.cshtml" })
.when("/dashboard", { templateUrl: "Manage/dashboard/index.cshtml" })
.when("/dashboard/serverinfo", { templateUrl: "Manage/dashboard/serverinfo.cshtml" })
.when("/dashboard/emaillogs", { templateUrl: "Manage/dashboard/emaillogs.cshtml" })
// other code....
.otherwise({ redirectTo: "/" });
}];
app.config(config);
最关键的就是最后的禁用IE对ajax的缓存
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
如果你想这样写,是会爆的:
$httpProvider.defaults.headers.get['If-Modified-Since'] = '0';
这样会导致include指令加载的partial view撸不出来,所以不要作死了
5、如何解决angular 前后端分离后,网站升级造成的缓存问题
把下面的代码加上试试
var app = angular.mole('phonecat', ['ngRoute']);
app.config(['$routeProvider', '$httpProvider',
function($routeProvider, $httpProvider) {
if (!$httpProvider.defaults.headers.get) {
$httpProvider.defaults.headers.get = {};
}
$httpProvider.defaults.headers.common["X-Requested-With"] = 'XMLHttpRequest';
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
$routeProvider.
when('/phones', {
templateUrl: 'phone-list.html',
controller: PhoneListCtrl
}).
when('/phones/:phoneId', {
templateUrl: 'phone-detail.html',
controller: PhoneDetailCtrl
}).
otherwise({
redirectTo: '/phones'
});
}
]);