« Highlight.js » : différence entre les versions
De Banane Atomic
Aller à la navigationAller à la recherche
(→Links) |
|||
(4 versions intermédiaires par le même utilisateur non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
[[Category:Javascript]] | [[Category:Javascript]] | ||
[[Category:Web]] | [[Category:Web]] | ||
= | = Links = | ||
* [https://highlightjs.org highlight.js] | * [https://highlightjs.org highlight.js] | ||
* [https://highlightjs.org/static/demo/ demo] | * [https://highlightjs.org/static/demo/ demo] | ||
Ligne 8 : | Ligne 8 : | ||
* [http://highlightjs.readthedocs.io/en/latest/language-contribution.html Language contributor checklist] | * [http://highlightjs.readthedocs.io/en/latest/language-contribution.html Language contributor checklist] | ||
* [http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html#language-names-and-aliases Language names and aliases] | * [http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html#language-names-and-aliases Language names and aliases] | ||
* [https://highlightjs.readthedocs.io/en/latest/css-classes-reference.html Scope Reference] | |||
* [https://highlightjs.readthedocs.io/en/latest/mode-reference.html Mode Reference] | |||
* [https://www.mediawiki.org/wiki/Extension:Highlightjs_Integration Highlightjs Integration Mediawiki extension] | |||
== External Languages == | |||
* [https://github.com/highlightjs/highlightjs-cshtml-razor Razor] | |||
* [https://github.com/highlightjs/highlightjs-tsql TSQL] | |||
= [https://highlightjs.readthedocs.io/en/latest/building-testing.html#building Build] = | = [https://highlightjs.readthedocs.io/en/latest/building-testing.html#building Build] = | ||
Ligne 42 : | Ligne 50 : | ||
* [https://highlightjs.readthedocs.io/en/latest/language-guide.html Language definition guide] | * [https://highlightjs.readthedocs.io/en/latest/language-guide.html Language definition guide] | ||
* [https://highlightjs.readthedocs.io/en/latest/reference.html Mode reference] | * [https://highlightjs.readthedocs.io/en/latest/reference.html Mode reference] | ||
<filebox fn='src/languages/[nouveau langage].js' lang='javascript' collapsed> | <filebox fn='src/languages/[nouveau langage].js' lang='javascript' collapsed> | ||
Ligne 56 : | Ligne 60 : | ||
function(hljs) { | function(hljs) { | ||
const KEYWORDS = { | |||
$pattern: /-[a-z]+/, | $pattern: /-[a-z]+/, | ||
keyword: 'abc def', | keyword: 'abc def', | ||
Ligne 64 : | Ligne 68 : | ||
}; | }; | ||
const comment = hljs.COMMENT( | |||
'//', // tout ce qui commence par // | '//', // tout ce qui commence par // | ||
'$' // jusqu'à la fin de la ligne | '$' // jusqu'à la fin de la ligne | ||
Ligne 89 : | Ligne 93 : | ||
* [http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html CSS classes reference] | * [http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html CSS classes reference] | ||
== Test == | |||
<filebox fn='test/detect/[nouveau langage]/default.txt' lang='nohighlight'> | |||
Code de démo | |||
</filebox> | |||
<filebox fn='test/markup/[nouveau langage]/default.txt' lang='nohighlight'> | |||
Code de démo | |||
<!-- comment --> | |||
</filebox> | |||
<filebox fn='test/markup/[nouveau langage]/default.expect.txt' lang='nohighlight'> | |||
Expected result | |||
<span class="hljs-comment"><!-- comment --></span> | |||
</filebox> | |||
== Pre-defined modes and regular expressions == | == Pre-defined modes and regular expressions == |
Dernière version du 8 avril 2023 à 17:15
Links
- highlight.js
- demo
- developer documentation
- GitHub
- Language contributor checklist
- Language names and aliases
- Scope Reference
- Mode Reference
External Languages
Build
git clone https://github.com/isagalaev/highlight.js cd highlight.js/ # installation des dépendances dans ./node_modules # npm i utilise le fichier package.json npm i # création du dossier build et de ses fichiers node tools/build.js -t browser -n :common csharp cpp # -t browser, target (browser, cdn, node, all) # -n, Disable compression # :common, langages de base # csharp cpp, les langages c# et c++ # the build result is in the build/ directory. |
Test
Après avoir buildé
- build/demo/index.html
- tools/developer.html
# run unit test cd test npm test |
Ajouter un nouveau langage
src/languages/[nouveau langage].js |
/* * Language: [nouveau langage] * Requires: xml.js, csharp.js * Author: Moi <moi@domaine.fr> * Category: common */ function(hljs) { const KEYWORDS = { $pattern: /-[a-z]+/, keyword: 'abc def', literal: 'null false true', type: 'string int', built_in: 'constant class function' }; const comment = hljs.COMMENT( '//', // tout ce qui commence par // '$' // jusqu'à la fin de la ligne ); const xxx = { scope: 'predefined scope', begin: '= ', end: ' =' }; return { aliases: ['name1', 'name2'], keywords: KEYWORDS, illegal: /::/, contains: [ // Sub-modes comment, hljs.HASH_COMMENT_MODE, // already defined comment pattern xxx ] }; } |
Test
test/detect/[nouveau langage]/default.txt |
Code de démo |
test/markup/[nouveau langage]/default.txt |
Code de démo <!-- comment --> |
test/markup/[nouveau langage]/default.expect.txt |
Expected result <span class="hljs-comment"><!-- comment --></span> |
Pre-defined modes and regular expressions
src/lib/modes.js |
export const IDENT_RE = '[a-zA-Z]\\w*'; export const TITLE_MODE = { scope: 'title', begin: IDENT_RE, relevance: 0 }; export const NUMBER_RE = '\\b\\d+(\\.\\d+)?'; export const NUMBER_MODE = { scope: 'number', begin: NUMBER_RE, relevance: 0 }; export const C_LINE_COMMENT_MODE = COMMENT('//', '$'); export const C_BLOCK_COMMENT_MODE = COMMENT('/\\*', '\\*/'); export const HASH_COMMENT_MODE = COMMENT('#', '$'); |
Category
assembler | common | config | css |
enterprise | functional | graphics | lisp |
markup | protocols | scientific | scripting |
system | template |
Installation
npm install -g highlight.js # highlight.js → /usr/lib/node_modules/highlight.js/lib/ # languages → /usr/lib/node_modules/highlight.js/lib/languages # css → /usr/lib/node_modules/highlight.js/styles/ |