


exemple de code js pour un site Web permettant de générer automatiquement l'index de la table des matières du chapitre
De nombreuses fonctions du site Web sont implémentées par js. Cet article présente principalement plusieurs codes js qui permettent au blog Blog Park de générer automatiquement un index de répertoire de chapitre. Les amis qui en ont besoin peuvent s'y référer.
Le premier type : ne prend en charge que les répertoires de premier niveau
, en tant que paragraphes, la classification n'est pas prise en charge
A bon article de blog En plus de la qualité des articles de blog, une bonne structure organisationnelle peut également rendre les lecteurs plus confortables et plus pratiques à lire. Je vois que les articles de blog de certains amis du jardin sont divisés en chapitres et qu'il existe un tableau de. index du contenu des chapitres devant les articles de blog. , après avoir cliqué sur l'index, vous passerez au chapitre correspondant à lire, et vous pourrez également revenir en haut du répertoire. L'article de blog de Fish Li est ce genre d'organisation. Bien sûr, si cette structure est définie manuellement lors de la rédaction d'un article de blog, cela augmentera sans aucun doute la charge de travail des rédacteurs. Cela ne permettrait-il pas d'économiser beaucoup de travail si l'index des chapitres pouvait être généré automatiquement ? Au départ, je voulais utiliser FireBug pour voir comment le code source de Fish Li est implémenté, mais il semble que le js soit crypté. Ensuite je l’ai fait moi-même. En fait, il n’y avait pas beaucoup de code, c’était très simple.
code html
<h3>章节1</h3> <p>这里是章节1的内容</p> <h3>章节2</h3> <p>这里是章节2的内容</p> <h3>章节3</h3> <p>这里是章节3的内容</p> <h3>章节4</h3> <p>小小代码,不值一提,如果您觉得对您还有一点用,就点个赞支持一下吧。</p>
code js
<script language="javascript" type="text/javascript"> //生成目录索引列表 function GenerateContentList() { var jquery_h3_list = $('#cnblogs_post_body h3');//如果你的章节标题不是h3,只需要将这里的h3换掉即可 if(jquery_h3_list.length>0) { var content = '<a name="_labelTop"></a>'; content += '<p id="navCategory">'; content += '<p style="font-size:18px"><b>阅读目录</b></p>'; content += '<ul>'; for(var i =0;i<jquery_h3_list.length;i++) { var go_to_top = '<p style="text-align: right"><a href="#_labelTop" rel="external nofollow" rel="external nofollow" >回到顶部</a><a name="_label' + i + '"></a></p>'; $(jquery_h3_list[i]).before(go_to_top); var li_content = '<li><a href="#_label' + i + '" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >' + $(jquery_h3_list[i]).text() + '</a></li>'; content += li_content; } content += '</ul>'; content += '</p>'; if($('#cnblogs_post_body').length != 0 ) { $($('#cnblogs_post_body')[0]).prepend(content); } } } GenerateContentList(); </script>
Utilisation : Connexion Une fois arrivé au parc de blogs, ouvrez la gestion backend du parc de blogs, passez à l'onglet « Paramètres » et collez le code ci-dessus dans la zone « Code HTML de pied de page » pour l'enregistrer.
Remarque : Le h3 extrait du code js ci-dessus est utilisé comme titre du chapitre. Si votre titre n'est pas h3, veuillez le modifier vous-même dans le commentaire du code. En plus de générer un index de table des matières au début de l'article, ce code générera également un lien "retour en haut" dans le coin inférieur droit de chaque chapitre (c'est-à-dire le coin supérieur droit du titre du chapitre suivant) pour faciliter le retour des lecteurs. Table des matières. La structure des répertoires de cet article est générée automatiquement. Si vous la trouvez utile, essayez-la rapidement.
Texte original : https://www.cnblogs.com/wangqiguo/p/4355032.html
Deuxième type : Prise en charge de la classification secondaire
Par
Rendu :
Pour les articles plus longs, il est nécessaire d'avoir un bon index de table des matières, qui permet aux lecteurs de comprendre plus clairement le contenu et le niveau de l’article. Cependant, à l'heure actuelle (2015.7), Blog Park ne génère pas automatiquement d'index de répertoire pour les articles publiés comme le blog csdn. Cependant, certains internautes ont implémenté cette fonction en écrivant leurs propres scripts via certaines fonctions personnalisées fournies par le backend du parc de blogs. Le script que j'ai utilisé fait principalement référence à la mélodie de @lavender. L'adresse de l'article est : http://www.cnblogs.com/wangqiguo/p/4355032.html.
Le script de l'auteur original ne prend en charge que les répertoires de niveau 1. J'ai modifié deux niveaux : le premier niveau est h2 et le deuxième niveau est h3. Certains gadgets ont également été ajoutés, comme les comptes de groupe de discussion QQ. L'effet est comme le montre la figure ci-dessous :
Les étapes spécifiques pour ajouter des fonctions sont :
Assurez-vous que le backend de votre parc de blogs prend en charge js
. Ceci n'est pas pris en charge par défaut. Je dois envoyer un e-mail officiel pour demander l'activation (l'adresse e-mail est contact@cnblogs.com). J'ai simplement écrit un e-mail et j'ai reçu une réponse dans l'heure. email : comme dans le titre. . . .
2. Ajoutez le script au backend
Ouvrez le backend du parc de blogs, entrez dans l'onglet "Paramètres", collez votre code js dans la zone d'édition correspondant au "Code HTML du pied de page" en bas, et puis cliquez sur le bouton "Enregistrer".
3. Rédigez des articles selon le format
Lors de la rédaction d'un nouvel article de blog, faites attention à diviser les chapitres selon le format défini dans votre script js, tel que h2, h3, etc. Bien entendu, si les articles déjà publiés contiennent h2, h3, etc., un index d'annuaire sera automatiquement généré.
est la suivante :
<script language="javascript" type="text/javascript"> // 生成目录索引列表 // ref: http://www.cnblogs.com/wangqiguo/p/4355032.html // modified by: zzq function GenerateContentList() { var mainContent = $('#cnblogs_post_body'); var h2_list = $('#cnblogs_post_body h2');//如果你的章节标题不是h2,只需要将这里的h2换掉即可 if(mainContent.length < 1) return; if(h2_list.length>0) { var content = '<a name="_labelTop"></a>'; content += '<p id="navCategory">'; content += '<p style="font-size:18px"><b>目录</b></p>'; content += '<ul>'; for(var i=0; i<h2_list.length; i++) { var go_to_top = '<p style="text-align: right"><a href="#_labelTop" rel="external nofollow" rel="external nofollow" >回到顶部</a><a name="_label' + i + '"></a></p>'; $(h2_list[i]).before(go_to_top); var h3_list = $(h2_list[i]).nextAll("h3"); var li3_content = ''; for(var j=0; j<h3_list.length; j++) { var tmp = $(h3_list[j]).prevAll('h2').first(); if(!tmp.is(h2_list[i])) break; var li3_anchor = '<a name="_label' + i + '_' + j + '"></a>'; $(h3_list[j]).before(li3_anchor); li3_content += '<li><a href="#_label' + i + '_' + j + '" rel="external nofollow" >' + $(h3_list[j]).text() + '</a></li>'; } var li2_content = ''; if(li3_content.length > 0) li2_content = '<li><a href="#_label' + i + '" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >' + $(h2_list[i]).text() + '</a><ul>' + li3_content + '</ul></li>'; else li2_content = '<li><a href="#_label' + i + '" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >' + $(h2_list[i]).text() + '</a></li>'; content += li2_content; } content += '</ul>'; content += '</p><p> </p>'; content += '<p style="font-size:18px"><b>正文</b></p>'; if($('#cnblogs_post_body').length != 0 ) { $($('#cnblogs_post_body')[0]).prepend(content); } } var qqinfo = '<p style="color:navy;font-size:12px">讨论QQ群:135202158</p>'; $(mainContent[0]).prepend(qqinfo); } GenerateContentList(); </script>
Troisième type : prend en charge les répertoires de troisième niveau
via
< ;h4> Implémentation des
rendus
Page de démonstration : http://www.jb51.net/article/132341.htm
Reportez-vous à la page de Zhang Guo, il utilise
, ici l'éditeur de Script House utilise , selon seo, un grand nombre des h1 apparaissant sur la page auront un impact sur le poids.
, ici l'éditeur de Script House utilise , selon seo, un grand nombre des h1 apparaissant sur la page auront un impact sur le poids.
, selon seo, un grand nombre des h1 apparaissant sur la page auront un impact sur le poids.
<script language="javascript" type="text/javascript"> //生成目录索引列表 function GenerateContentList() { var jquery_h1_list = $('#content h2'); if (jquery_h1_list.length == 0) { return; } if ($('#content').length == 0) { return; } var content = '<a name="_labelTop"></a>'; content += '<p id="navCategory">'; content += '<p style="font-size:18px"><b>目录</b></p>'; // 一级目录 start content += '<ul class="first_class_ul">'; for (var i = 0; i < jquery_h1_list.length; i++) { var go_to_top = '<p style="text-align: right"><a name="_label' + i + '"></a></p>'; $(jquery_h1_list[i]).before(go_to_top); // 一级目录的一条 var li_content = '<li><a href="#_label' + i + '" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >' + $(jquery_h1_list[i]).text() + '</a></li>'; var nextH1Index = i + 1; if (nextH1Index == jquery_h1_list.length) { nextH1Index = 0; } var jquery_h2_list = $(jquery_h1_list[i]).nextUntil(jquery_h1_list[nextH1Index], "h3"); // 二级目录 start if (jquery_h2_list.length > 0) { //li_content +='<ul style="list-style-type:none; text-align: left; margin:2px 2px;">'; li_content += '<ul class="second_class_ul">'; } for (var j = 0; j < jquery_h2_list.length; j++) { var go_to_top2 = '<p style="text-align: right"><a name="_lab2_' + i + '_' + j + '"></a></p>'; $(jquery_h2_list[j]).before(go_to_top2); // 二级目录的一条 li_content += '<li><a href="#_lab2_' + i + '_' + j + '" rel="external nofollow" >' + $(jquery_h2_list[j]).text() + '</a></li>'; var nextH2Index = j + 1; var next; if (nextH2Index == jquery_h2_list.length) { if (i + 1 == jquery_h1_list.length) { next = jquery_h1_list[0]; } else { next = jquery_h1_list[i + 1]; } } else { next = jquery_h2_list[nextH2Index]; } var jquery_h3_list = $(jquery_h2_list[j]).nextUntil(next, "h4"); // 三级目录 start if (jquery_h3_list.length > 0) { li_content += '<ul class="third_class_ul">'; } for (var k = 0; k < jquery_h3_list.length; k++) { var go_to_third_Content = '<p style="text-align: right"><a name="_label3_' + i + '_' + j + '_' + k + '"></a></p>'; $(jquery_h3_list[k]).before(go_to_third_Content); // 三级目录的一条 li_content += '<li><a href="#_label3_' + i + '_' + j + '_' + k + '" rel="external nofollow" >' + $(jquery_h3_list[k]).text() + '</a></li>'; } if (jquery_h3_list.length > 0) { li_content += '</ul>'; } li_content += '</li>'; // 三级目录 end } if (jquery_h2_list.length > 0) { li_content += '</ul>'; } li_content += '</li>'; // 二级目录 end content += li_content; } // 一级目录 end content += '</ul>'; content += '</p>'; $($('#content')[0]).prepend(content); } GenerateContentList(); </script>
L'avez-vous appris ? Essayez-le maintenant.
Recommandations associées :
PHP interdit l'affichage de l'index du répertoire
Partage d'instance de moteur de recherche de simulation interdomaine jQuery Jsonp
php convertit le tableau d'index en json
Résumé de l'opération d'indexation de la base de données MySQL
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de reconnaissance vocale en ligne Introduction : Avec le développement continu de la technologie, la technologie de reconnaissance vocale est devenue une partie importante du domaine de l'intelligence artificielle. Le système de reconnaissance vocale en ligne basé sur WebSocket et JavaScript présente les caractéristiques d'une faible latence, d'un temps réel et d'une multiplateforme, et est devenu une solution largement utilisée. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de reconnaissance vocale en ligne.

WebSocket et JavaScript : technologies clés pour réaliser des systèmes de surveillance en temps réel Introduction : Avec le développement rapide de la technologie Internet, les systèmes de surveillance en temps réel ont été largement utilisés dans divers domaines. L'une des technologies clés pour réaliser une surveillance en temps réel est la combinaison de WebSocket et de JavaScript. Cet article présentera l'application de WebSocket et JavaScript dans les systèmes de surveillance en temps réel, donnera des exemples de code et expliquera leurs principes de mise en œuvre en détail. 1. Technologie WebSocket

Introduction à l'utilisation de JavaScript et de WebSocket pour mettre en œuvre un système de commande en ligne en temps réel : avec la popularité d'Internet et les progrès de la technologie, de plus en plus de restaurants ont commencé à proposer des services de commande en ligne. Afin de mettre en œuvre un système de commande en ligne en temps réel, nous pouvons utiliser les technologies JavaScript et WebSocket. WebSocket est un protocole de communication full-duplex basé sur le protocole TCP, qui peut réaliser une communication bidirectionnelle en temps réel entre le client et le serveur. Dans le système de commande en ligne en temps réel, lorsque l'utilisateur sélectionne des plats et passe une commande

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de réservation en ligne. À l'ère numérique d'aujourd'hui, de plus en plus d'entreprises et de services doivent fournir des fonctions de réservation en ligne. Il est crucial de mettre en place un système de réservation en ligne efficace et en temps réel. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de réservation en ligne et fournit des exemples de code spécifiques. 1. Qu'est-ce que WebSocket ? WebSocket est une méthode full-duplex sur une seule connexion TCP.

JavaScript et WebSocket : Construire un système efficace de prévisions météorologiques en temps réel Introduction : Aujourd'hui, la précision des prévisions météorologiques revêt une grande importance pour la vie quotidienne et la prise de décision. À mesure que la technologie évolue, nous pouvons fournir des prévisions météorologiques plus précises et plus fiables en obtenant des données météorologiques en temps réel. Dans cet article, nous apprendrons comment utiliser la technologie JavaScript et WebSocket pour créer un système efficace de prévisions météorologiques en temps réel. Cet article démontrera le processus de mise en œuvre à travers des exemples de code spécifiques. Nous

WPS est un logiciel de bureau puissant qui peut nous aider à accomplir efficacement diverses tâches de bureau. Parmi eux, générer automatiquement des numéros de page de table des matières est une fonction très pratique. Cela peut considérablement améliorer l'efficacité du travail des utilisateurs, c'est pourquoi l'éditeur de ce site Web vous proposera cet article pour vous présenter en détail comment utiliser WPS pour générer automatiquement des numéros de page d'annuaire. J'espère que cela pourra aider tous ceux qui en ont besoin. Comment générer automatiquement les numéros de page de la table des matières pour un répertoire wps. Tout d'abord, ouvrez le document du groupe wps, entrez le contenu de la table des matières à générer dans l'espace vide, puis sélectionnez les styles du titre 1, du titre 2, et le titre 3 dans la barre de menu Démarrer. 2. Ensuite, après l'avoir configuré, nous cliquons sur la fonction [Référence]. Après avoir cliqué, dans la barre d'outils de référence, nous cliquons ici sur [Répertoire] 3. Enfin, cliquez sur [Répertoire] ;

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

Sélectionnez le style du catalogue dans Word, et il sera automatiquement généré une fois l'opération terminée. Analyse 1. Accédez à Word sur votre ordinateur et cliquez pour importer. 2Après avoir entré, cliquez sur le répertoire du fichier. 3 Sélectionnez ensuite le style du répertoire. 4. Une fois l'opération terminée, vous pouvez voir que le répertoire de fichiers est automatiquement généré. Supplément : la table des matières de l'article de résumé/notes est générée automatiquement, y compris les titres de premier niveau, les titres de deuxième niveau et les titres de troisième niveau, généralement pas plus que les titres de troisième niveau.
