Indexation et Javascript,
où en est-on ?
Seocamp’us Paris - 7 avril 2016 - Madeline Pinthon
Qui suis-je ?
Madeline Pinthon
Consultante SEO chez iProspect
• Diplômée d’Audencia Nantes
• 4 ans chez l’annonceur
• 1 an...
Comment se déroulera la conférence
L’évolution de la communication de Google
Point
Un
Des paroles aux actes (les tests)
Po...
Ce que dit Google
Avant, il fallait désactiver le javascript
La communication de Google évolue
Avril 2014
Question : how doesGoogle
handle content loaded via
Javascript ?
VIDEO DE MAT...
2015
En bloquant les ressources,
votre classement risque de ne
pas être optimal
RAPPORT RESSOURCES
BLOQUES
Octobre 2015
We...
Février 2016
Accélerer le mobile…avec du
JSON-LD
AMP
mars 2016
Message de John Mueller
résumant les recommandations
de Goo...
Les conseils de John
Don't cloak to Googlebot. Use
"feature detection" &
"progressive enhancement"
techniques to make your...
Les conseils de John
Use rel=canonical when serving
content from multiple URLs is
required.
“
Les conseils de John
Avoid the AJAX-Crawling
scheme on new sites. Consider
migrating old sites that use this
scheme soon.
...
Les conseils de John
Avoid using "#" in URLs (outside
of "#!"). Googlebot rarely
indexes URLs with "#" in them.
Use "norma...
Les conseils de John
Use Search Console's Fetch and
Render tool to test how
Googlebot sees your pages.
Note that this tool...
Les conseils de John
Limit the number of embedded
resources, in particular the
number of JavaScript files and
server respo...
Les conseils de John
Google supports the use of
JavaScript to provide titles,
description & robots meta tags,
structured d...
Les conseils de John
Finally, keep in mind that other
search engines and web services
accessing your content might
not sup...
De la théorie à la pratique
Réecrire les title
Lorsqu’on réécrit les balises title en javascript, est-ce pris en compte ?
Le DOM est pris en compte.
L...
Exemple
C’est bien le DOM qui est pris en compte, et non pas le code source.
Code source DOM
Google
Modifier et/ou insérer des paragraphes
Lorsqu’on ajoute dynamiquement du contenu avec du javascript, ces contenus sont-ils...
Sans JS
CFPJ : formation communication orale
Avec JS
Dans google…
Autres tests…de 2013
http://www.klikki.com/blog/google-able-index-content-fetched-using-ajax
Injecter du contenu
Le conten...
Injection d’un contenu bloqué
Injecter du contenu, en provenance d’une URL bloquée par le robots.txt
Le contenu était bien...
Injection l’affichage demande un clic
Un contenu a été injecté mais il s’affiche après un clic
KO, le contenu n’avait pas ...
D’autres tests en 2015
http://www.centrical.com/test/google-json-ld-and-javascript-crawling-and-indexing-test.html
Plusieu...
Les liens javascript
Des liens insérés en JS sont-ils crawlés ?
Les liens ont été crawlés.
Sans JS
(Merci Walid, http://www.trafic-organique.com/javascript-seo.html )
Avec JS
Les redirections
Comment sont considérées les redirections javascript ?
Les redirections sont bien prises en compte…
et as...
Illustration dans search console
Malgré un code 200, Google voit la redirection.
Les redirections avec temps d’attente ?
Une redirection javascript qui se déclenche après un timer ?
Ca passe également ! ...
Encore des tests
http://searchengineland.com/tested-googlebot-crawls-javascript-heres-learned-220157
Désindexer un contenu
Nous avons injecté dynamiquement une balise noindex.
Le contenu a-t-il été désindexé ?
OK, la page a...
Mise en place simple d’un script qui injecte la meta robots
Sur
www.canyouseome.com/
page-c/, il n’y a aucune
balise meta ...
Retirer une balise noindex
Nous avons mis un script pour retirer la balise meta robots :
KO, la page n’a pas été réindexée
Résultat
Sur http://canyouseome.com/page-d/, la balise meta robots est présente dans le code source mais pas dans
le DOM.
Un site fait avec AngularJS s’indexe-t-il ?
Le JavaScript utilisé dans Angular ou d’autres framework JS est complexe.
Goog...
En conclusion
Quelques enseignements
• Le DOM prime. Ne vous fiez plus au code source.
• Si des instructions contradictoires sont donnée...
Un site doit-il passer sur un framework JS (type Angular)?
Le site a-t-il une certaine autorité ?
Bing apporte-t-il une pa...
Ne négligez pas l’accessibilité
• Utilisez les sitemaps
• Ajoutez des micro données
• Le DOM et le rendu final doit être d...
Quels outils SEO pour
exécuter le JS ?
L’outil « explorer comme Google »
Google Search Console et l’outil Explorer commeGoogle (Affichage)
Les tests sont nécessa...
PhantomJS
Le meilleur outil…. PhantomJS.
Mais il faut aimer la technique !
SEOTools for excel
Excel seo tools et PhantomJS : http://seotoolsforexcel.com/phantomjs-cloud/
Il faut juste connaître le ...
Un crawler qui exécute le JS ?
Pas de produit sur le marché actuellement…
(coucou Botify,onCrawl, etc.)
GoogleTag Manager
Peut devenir unCMS (réécrire des titres, injecter du contenu, etc.)
http://startup-metrics.fr/gtm-tips-3...
Merci!Vos questions?
Madeline Pinthon
Madeline.pinthon@iprospect.com @razbithume
Le 7 avril 2016
Rejoignez-nous, on recrute !
Prochain SlideShare
Chargement dans…5
×

Javascript et indexation, où en est-on ? - SEO Camp'us Paris 2016

6 710 vues

Publié le

Le jeudi 7 avril à 11h45, Madeline Pinthon a donné une conférence sur les bonnes pratiques du Javascript pour indexer les pages sur les moteurs de recherche.

Publié dans : Marketing
0 commentaire
6 j’aime
Statistiques
Remarques
  • Soyez le premier à commenter

Aucun téléchargement
Vues
Nombre de vues
6 710
Sur SlideShare
0
Issues des intégrations
0
Intégrations
1 320
Actions
Partages
0
Téléchargements
64
Commentaires
0
J’aime
6
Intégrations 0
Aucune incorporation

Aucune remarque pour cette diapositive
  • https://support.google.com/webmasters/answer/81766
  • https://webmasters.googleblog.com/2014/03/musical-artists-your-official-tour.html
    JSON et knowledge graph

    https://www.youtube.com/watch?v=_6mtiwQ3nvw

    https://googlewebmastercentral.blogspot.fr/2014/05/understanding-web-pages-better.html


  • https://webmasters.googleblog.com/2015/01/new-structured-data-testing-tool.html
    https://googlewebmastercentral.blogspot.fr/2015/03/easier-website-development-with-web.html
    https://googlewebmastercentral.blogspot.fr/2015/10/deprecating-our-ajax-crawling-scheme.html

  • https://www.ampproject.org/docs/guides/discovery.html
    https://plus.google.com/+JohnMueller/posts/LT4fU7kFB8W
  • When using AMP, the AMP HTML page must be static as required by the spec, but the associated web page can be built using JS/PWA techniques. Remember to use a sitemap file with correct "lastmod" dates for signaling changes on your website.
  • When using AMP, the AMP HTML page must be static as required by the spec, but the associated web page can be built using JS/PWA techniques. Remember to use a sitemap file with correct "lastmod" dates for signaling changes on your website.
  • http://www.klikki.com/blog/google-able-index-content-fetched-using-ajax
  • http://www.klikki.com/blog/google-able-index-content-fetched-using-ajax
  • http://www.klikki.com/blog/google-able-index-content-fetched-using-ajax
  • Fetch as Google :
    Encourageant mais n’est pas forcément conforme au comportement de Google.
    Il faut demander l’affchage. Si l’affichage est OK, il y a de grandes chances que le site soit OK….mais ce n’est pas sûr à 100% non plus.
    Le crawl fetch est légèrement différent.

    Le code source est bel et bien le code source, pas le dom => on ne voit pas ce qui est vraiment interprété.

    C’est nécessaire mais pas suffisant.
  • https://builtvisible.com/javascript-framework-seo/
    http://www.angularjsseo.com/
    https://weluse.de/blog/angularjs-seo-finally-a-piece-of-cake.html
    http://www.ng-newsletter.com/posts/serious-angular-seo.html
    http://stackoverflow.com/questions/13499040/how-do-search-engines-deal-with-angularjs-applications
    https://googlewebmastercentral.blogspot.no/2014/05/understanding-web-pages-better.html
    http://rogeralsing.com/2013/08/11/angularjs-and-seo-part-1/
    http://rogeralsing.com/2013/08/11/angularjs-and-seo-part-2/
    http://ng-learn.org/2014/05/SEO-Google-crawl-JavaScript/
    https://www.kcoleman.me/blog/2014/10/03/angularjs-rails-seo/
    https://www.kcoleman.me/blog/2014/10/07/angularjs-rails-and-seo-part-2/
    http://www.algoworks.com/blog/a-developers-guide-to-perform-seo-on-angularjs-web-apps
    https://mobinni.io/2015/06/03/a-comprehensive-view-on-seo-in-angularjs/
    http://iranreyes.com/complete-guide-to-seo-with-angularjs/
     
    Prerender Your AngularJS Apps To Boost SEO
    https://www.youtube.com/watch?v=iYEQMJc1yak
    AngularJS Israel - Solving Angular & SEO with Oleg Belausov
    https://www.youtube.com/watch?v=a7rWmNBhHCg
    SEO and JavaScript: New Challenges
    https://www.youtube.com/watch?v=0jtrAUM3i_I
     
    https://www.seo4ajax.com/
    https://www.deepcrawl.com/knowledge/best-practice/angular-js-and-seo/

    https://www.seroundtable.com/google-seo-javascript-angular-hangout-20292.html
    http://www.bee4.fr/blog/seo/google-ajax-angularjs-phantomjs/
    https://www.searchenginejournal.com/warning-youre-killing-seo-efforts-using-angular-js/142031/
    http://www.doz.com/search-engine/angularjs-index-seo
    http://www.ocpsoft.org/java/seo-friendly-angularjs-with-html5-pushstate-rewrite-and-twelve-lines-of-code/
    http://blog.octo.com/seo-spa-angular/

    https://www.grobmeier.de/seo-and-angular-20012016.html
    https://plus.google.com/events/ci85lav8bdnjl356n5o0fkegb44
    http://www.rimmkaufman.com/blog/google-crawling-javascript/13052015/




  • Javascript et indexation, où en est-on ? - SEO Camp'us Paris 2016

    1. 1. Indexation et Javascript, où en est-on ? Seocamp’us Paris - 7 avril 2016 - Madeline Pinthon
    2. 2. Qui suis-je ? Madeline Pinthon Consultante SEO chez iProspect • Diplômée d’Audencia Nantes • 4 ans chez l’annonceur • 1 an chez iProspect J’en profite pour remercier : • Mes collèges & clients • Les events SEO (teknseo, seocamp, visibilite live camp, google black day) • www.scripts-seo.com • Les SEO sur twitter, skype,…
    3. 3. Comment se déroulera la conférence L’évolution de la communication de Google Point Un Des paroles aux actes (les tests) Point deux Les outils utiles Point Trois
    4. 4. Ce que dit Google
    5. 5. Avant, il fallait désactiver le javascript
    6. 6. La communication de Google évolue Avril 2014 Question : how doesGoogle handle content loaded via Javascript ? VIDEO DE MATT CUTTS Mars 2014 Le JSON peut alimenter le knowledge graph WEBMASTER Mai 2014 “we decided to try to understand pages by executing JavaScript.” UNDERSTANDINGWEB PAGES BETTER
    7. 7. 2015 En bloquant les ressources, votre classement risque de ne pas être optimal RAPPORT RESSOURCES BLOQUES Octobre 2015 We are generally able to render and understand your web pages like modern browsers. DEPRECATING AJAX CRAWLING SCHEME Octobre 2015 GTMV2 Lancement deAngularJS 2.0 LANCEMENT DE NOUVEAUX OUTILS Janvier 2015 La nouvelle version comprend le JSON-LD NOUVEL OUTIL DETEST DES RICH SNIPPETS Avril 2015 Google doit interpréter les CSS pour voir si un site est mobile- friendly MOBILEGEDDON
    8. 8. Février 2016 Accélerer le mobile…avec du JSON-LD AMP mars 2016 Message de John Mueller résumant les recommandations de Google sur le Javascript. SYNTHESE DES CONSEILS SUR L’INDEXATION DU JS
    9. 9. Les conseils de John Don't cloak to Googlebot. Use "feature detection" & "progressive enhancement" techniques to make your content available to all users.“
    10. 10. Les conseils de John Use rel=canonical when serving content from multiple URLs is required. “
    11. 11. Les conseils de John Avoid the AJAX-Crawling scheme on new sites. Consider migrating old sites that use this scheme soon. Remember to remove "meta fragment" tags when migrating. Don't use a "meta fragment" tag if the "escaped fragment" URL doesn't serve fully rendered content. “
    12. 12. Les conseils de John Avoid using "#" in URLs (outside of "#!"). Googlebot rarely indexes URLs with "#" in them. Use "normal" URLs with path/filename/query- parameters instead, consider using the History API for navigation. “
    13. 13. Les conseils de John Use Search Console's Fetch and Render tool to test how Googlebot sees your pages. Note that this tool doesn't support "#!" or "#" URLs.“
    14. 14. Les conseils de John Limit the number of embedded resources, in particular the number of JavaScript files and server responses required to render your page. A high number of required URLs can result in timeouts & rendering without these resources being available “
    15. 15. Les conseils de John Google supports the use of JavaScript to provide titles, description & robots meta tags, structured data, and other meta- data.“
    16. 16. Les conseils de John Finally, keep in mind that other search engines and web services accessing your content might not support JavaScript at all, or might support a different subset. “
    17. 17. De la théorie à la pratique
    18. 18. Réecrire les title Lorsqu’on réécrit les balises title en javascript, est-ce pris en compte ? Le DOM est pris en compte. Le title du code source n’est plus visible.
    19. 19. Exemple C’est bien le DOM qui est pris en compte, et non pas le code source. Code source DOM Google
    20. 20. Modifier et/ou insérer des paragraphes Lorsqu’on ajoute dynamiquement du contenu avec du javascript, ces contenus sont-ils indexés ? Les pages peuvent se positionner sur les contenus injectés
    21. 21. Sans JS CFPJ : formation communication orale
    22. 22. Avec JS
    23. 23. Dans google…
    24. 24. Autres tests…de 2013 http://www.klikki.com/blog/google-able-index-content-fetched-using-ajax Injecter du contenu Le contenu était bien indexé
    25. 25. Injection d’un contenu bloqué Injecter du contenu, en provenance d’une URL bloquée par le robots.txt Le contenu était bien indexé
    26. 26. Injection l’affichage demande un clic Un contenu a été injecté mais il s’affiche après un clic KO, le contenu n’avait pas été indexé
    27. 27. D’autres tests en 2015 http://www.centrical.com/test/google-json-ld-and-javascript-crawling-and-indexing-test.html Plusieurs tests réalisés : injection avant et apres le chargement du DOM, en asyncrhone ou apres httpRequest. Le contenu était bien indexé
    28. 28. Les liens javascript Des liens insérés en JS sont-ils crawlés ? Les liens ont été crawlés.
    29. 29. Sans JS (Merci Walid, http://www.trafic-organique.com/javascript-seo.html )
    30. 30. Avec JS
    31. 31. Les redirections Comment sont considérées les redirections javascript ? Les redirections sont bien prises en compte… et assimilées à des 301
    32. 32. Illustration dans search console Malgré un code 200, Google voit la redirection.
    33. 33. Les redirections avec temps d’attente ? Une redirection javascript qui se déclenche après un timer ? Ca passe également ! Et elle peut également avoir le même effet qu’une 301.
    34. 34. Encore des tests http://searchengineland.com/tested-googlebot-crawls-javascript-heres-learned-220157
    35. 35. Désindexer un contenu Nous avons injecté dynamiquement une balise noindex. Le contenu a-t-il été désindexé ? OK, la page a disparu des SERP
    36. 36. Mise en place simple d’un script qui injecte la meta robots Sur www.canyouseome.com/ page-c/, il n’y a aucune balise meta robots dans le code source. Elle est par contre présente dans le DOM.
    37. 37. Retirer une balise noindex Nous avons mis un script pour retirer la balise meta robots : KO, la page n’a pas été réindexée
    38. 38. Résultat Sur http://canyouseome.com/page-d/, la balise meta robots est présente dans le code source mais pas dans le DOM.
    39. 39. Un site fait avec AngularJS s’indexe-t-il ? Le JavaScript utilisé dans Angular ou d’autres framework JS est complexe. Google a encore bien du mal l’interpréter. L’escaped fragment reste une manière efficace de donner le contenu à Google et d’indexer les pages.
    40. 40. En conclusion
    41. 41. Quelques enseignements • Le DOM prime. Ne vous fiez plus au code source. • Si des instructions contradictoires sont données sur l’indexation, la négation l’emporte, JS executé ou code source (c’est un peu moins vrai pour le nofollow). • Google ne fait pas d’interaction. • Tant que le rendu est du html propre, il n’y a pas de problème d’indexation. • Le javascript ne doit pas non plus être trop complexe. Il ne doit pas y avoir trop de fichiers à charger. • Si vous ne voulez pas que le JS soit interprété : bloquez l’accès à Google (en passant par un domaine externe bloqué par un robots.txt par exemple)
    42. 42. Un site doit-il passer sur un framework JS (type Angular)? Le site a-t-il une certaine autorité ? Bing apporte-t-il une part conséquente de trafic ? Etes-vous prêt à traverser une zone de turbulence ? Les équipes techniques sont-elles sensibles au SEO ? Oui Non Oui Non Oui Oui Ok (mais bon courage !) Oui (ou pas du tout) Votre site a-t-il beaucoup de pages ? Non Non
    43. 43. Ne négligez pas l’accessibilité • Utilisez les sitemaps • Ajoutez des micro données • Le DOM et le rendu final doit être du HTML classique
    44. 44. Quels outils SEO pour exécuter le JS ?
    45. 45. L’outil « explorer comme Google » Google Search Console et l’outil Explorer commeGoogle (Affichage) Les tests sont nécessaires mais pas suffisants !
    46. 46. PhantomJS Le meilleur outil…. PhantomJS. Mais il faut aimer la technique !
    47. 47. SEOTools for excel Excel seo tools et PhantomJS : http://seotoolsforexcel.com/phantomjs-cloud/ Il faut juste connaître le xpath.
    48. 48. Un crawler qui exécute le JS ? Pas de produit sur le marché actuellement… (coucou Botify,onCrawl, etc.)
    49. 49. GoogleTag Manager Peut devenir unCMS (réécrire des titres, injecter du contenu, etc.) http://startup-metrics.fr/gtm-tips-3-javascript-seo-friendly-avec-google-tag-manager-le-cas-resultats-du- bac/
    50. 50. Merci!Vos questions? Madeline Pinthon Madeline.pinthon@iprospect.com @razbithume Le 7 avril 2016
    51. 51. Rejoignez-nous, on recrute !

    ×