Maison >développement back-end >tutoriel php >Code d'implémentation de l'outil de gestion de documents PHP Markdown
Cet article partage principalement avec vous le code d'implémentation de l'outil de gestion de documents PHP markdown, dans l'espoir d'aider tout le monde.
Objectifs principaux :
1. Peut être modifié par plusieurs personnes
2 Peut être visualisé dans un navigateur
3. contents
4. Prend en charge les répertoires multi-niveaux
5. Prend en charge le markdown
6. Rapide et pratique
Je suis engagé dans le développement PHP depuis mon enfance. travail précédent. Bao Dalaan a été relégué à l'écriture d'interfaces côté serveur. Il est entré en contact avec plusieurs outils ou systèmes de gestion de documents d'interface. Voici une brève description :
showdoc, qui est complet et concis. Utilisateur, fonction de gestion des droits, prend en charge le démarque, prend en charge l'exportation de mots, dispose d'une variété de modèles de documents, le répertoire prend en charge le pliage à deux niveaux
confluence, fonctions puissantes ( gestion des droits, rappels par email, recherche en texte intégral, gestion des plug-ins, etc.), système de gestion de documents lourd et payant
swagger, qui nécessite écrire beaucoup de commentaires dans le code pour coopérer
readmine, riche en fonctions similaires à confluence, ses documents sont enregistrés en txt, les modifications peuvent être tracées et la recherche en texte intégral est disponible , mais écrire des documents est un peu pénible, adapté à la gestion du suivi des tâches/bugs, etc.
Gitbook, installation de nodejs, prend en charge le markdown, prend en charge les plug-ins npm. la gauche doit installer des plug-ins, et vous pouvez également installer des plug-ins de recherche. Les répertoires sont des fichiers de démarques séparés. Lorsque je les utilise, j'ai l'impression que la compilation de md à HTML est trop lente (plus de 600 documents, cela prend plus de temps). plus de 25 minutes pour compiler. S'il existe des plug-ins pour une compilation incrémentielle ou pour améliorer la vitesse de compilation, veuillez m'éclairer
. Cela peut être réalisé en combinant avec git, et vous pouvez également utiliser la fonction de gestion des autorisations de git
Vous devez compiler le markdown dans un fichier HTML et le déployer sur l'intranet
Parce que je souhaite le visualiser dans un navigateur, j'ai finalement choisi dtree.js avec un accès simple, une interface propre et sans dépendances (ne repose pas sur jQuery)
Cette fonction utilise l'algorithme de parcours d'ordre post-racine de l'arborescence pour réaliser la lecture de fichiers multi-niveaux (la récursion n'est pas utilisée et j'ai peur d'avoir des ennuis lors de l'écriture). prend également en charge le pliage de répertoires multi-niveaux
Ici, j'ai finalement choisi la classe d'outil de compilation PHP officiellement produite par segmentfault (car ils ont déjà référencé et optimisé de nombreuses classes PHP similaires, merci~)
Rapide Si vous souhaitez compiler plus de 600 fichiers, PHP prend environ 2 secondes, ce qui est acceptable, et il prend en charge la compilation incrémentielle si cela est pratique, cela se reflète principalement dans le fait ; que le répertoire est généré automatiquement, et qu'il n'est pas nécessaire d'écrire le répertoire séparément
Au premier démarrage pour juger si un fichier md doit être compilé en HTML, on compare l'heure de création et l'heure de dernière modification du fichier md,
Mais plus tard j'ai découvert que cette méthode ne fonctionnait pas pour certains fichiers copiés et renommés <.>Enfin, un fichier intermédiaire a été utilisé pour enregistrer l'heure du fichier compilé, puis suivi de max( Comparer l'heure de création, l'heure de la dernière modification) pour déterminer si une compilation est nécessaire
Par conséquent, lors de la compilation, une différence sera faite entre le fichier md et le fichier HTML final. , et ces fichiers HTML redondants seront supprimés.
du code dtree.js, et l'assemblage HTML d'embellissement
Prise en charge des répertoires multi-niveaux
Recommandations associées :
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!