Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/steeve/angular-seo
SEO for AngularJS apps made easy.
https://github.com/steeve/angular-seo
Last synced: about 1 month ago
JSON representation
SEO for AngularJS apps made easy.
- Host: GitHub
- URL: https://github.com/steeve/angular-seo
- Owner: steeve
- Created: 2012-12-25T21:41:20.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2015-12-01T12:51:00.000Z (about 9 years ago)
- Last Synced: 2024-11-29T02:12:41.943Z (about 1 month ago)
- Size: 269 KB
- Stars: 1,060
- Watchers: 54
- Forks: 127
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Angular-SEO
-----------SEO for AngularJS apps made easy. Based on [PhantomJS](http://phantomjs.org/) and [yearofmoo's article](http://www.yearofmoo.com/2012/11/angularjs-and-seo.html).
Requirements
============You will need [PhantomJS](http://phantomjs.org/) to make this work, as it will render the application to HTML.
How to use
==========The solution is made of 3 parts:
- small modification of your static HTML file
- an AngularJS module, that you have to include and call
- PhantomJS scriptModifying your static HTML
==========================Just add this to your `` to enable AJAX indexing by the crawlers.
```
```AngularJS Module
================Just include `angular-seo.js` and then add the `seo` module to you app:
```
angular.module('app', ['ng', 'seo']);
```If you are using [RequireJS](http://requirejs.org/), the script will detect it and auto define itself *BUT* you will need to have an `angular` shim defined, as `angular-seo` requires it:
```
requirejs.config({
paths: {
angular: 'http://cdnjs.cloudflare.com/ajax/libs/angular.js/1.0.3/angular.min',
},
shim: {
angular: {
exports: 'angular'
}
}
});
```Then you must call `$scope.htmlReady()` when you think the page is complete. This is necessary because of the async nature of AngularJS (such as with AJAX calls).
```
function MyCtrl($scope) {
Items.query({}, function(items) {
$scope.items = items;
$scope.htmlReady();
});
}
```If you have a complicated AJAX applicaiton running, you might want to automate this proccess, and call this function on the config level.
**Please that this is only a suggestion we've came up with in order to make your life easier, and might work great with some set-ups, while not working at all with others, overall, you should try it yourself and see if it's a good fit for your needs.**
There's alwasys the basic setup of calling $rootScope.htmlReady() from the controller.Example:
```javascript
var app = angular.module('myApp', ['angular-seo'])
.config(function($routeProvider, $httpProvider){
$locationProvider.hashPrefix('!');
$routeProvider.when({...});var $http,
interceptor = ['$q', '$injector', function ($q, $injector) {
var error;
function success(response) {
$http = $http || $injector.get('$http');
var $timeout = $injector.get('$timeout');
var $rootScope = $injector.get('$rootScope');
if($http.pendingRequests.length < 1) {
$timeout(function(){
if($http.pendingRequests.length < 1){
$rootScope.htmlReady();
}
}, 700);//an 0.7 seconds safety interval, if there are no requests for 0.7 seconds, it means that the app is through rendering
}
return response;
}function error(response) {
$http = $http || $injector.get('$http');return $q.reject(response);
}return function (promise) {
return promise.then(success, error);
}
}];$httpProvider.responseInterceptors.push(interceptor);
```And that's all there is to do on the app side.
PhantomJS Module
================For the app to be properly rendered, you will need to run the `angular-seo-server.js` with PhantomJS.
Make sure to disable caching:
```
$ phantomjs --disk-cache=no angular-seo-server.js [port] [URL prefix]
````URL prefix` is the URL that will be prepended to the path the crawlers will try to get.
Some examples:
```
$ phantomjs --disk-cache=no angular-seo-server.js 8888 http://localhost:8000/myapp
$ phantomjs --disk-cache=no angular-seo-server.js 8888 file:///path/to/index.html
```Testing the setup
=================Google and Bing replace `#!` (hashbang) with `?_escaped_fragment_=` so `http://localhost/app.html#!/route` becomes `http://localhost/app.html?_escaped_fragment_=/route`.
So say you app is running on `http://localhost:8000/index.html` (works with `file://` URLs too).
First, run PhantomJS:
```
$ phantomjs --disk-cache=no angular-seo-server.js 8888 http://localhost:8000/index.html
Listening on 8888...
Press Ctrl+C to stop.
```Then try with cURL:
```
$ curl 'http://localhost:8888/?_escaped_fragment_=/route'
```You should then have a complete, rendered HTML output.
Running in behind Nginx (or other)
==================================Of course you don't want regular users to see this, only crawlers.
To detect that, just look for an `_escaped_fragment_` in the query args.For instance with Nginx:
```
if ($args ~ _escaped_fragment_) {
# Proxy to PhantomJS instance here
}
```
[![githalytics.com alpha](https://cruel-carlota.pagodabox.com/3a55c16a191c4c8222beddcf429c2608 "githalytics.com")](http://githalytics.com/steeve/angular-seo)