Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
@speed-highlight/core
Advanced tools
🌈 Light, fast, and easy to use, dependencies free javascript syntax highlighter, with automatic language detection
Light, fast, and easy to use, dependencies free javascript syntax highlighter, with automatic language detection, try it out here
Blazing fast highlighting using regex
Style/theme (in the header of your html file):
<link rel="stylesheet" href="/path/dist/themes/default.css">
In the body of your html file:
<div class='shj-lang-[code-language]'>[code]</div>
or
<code class='shj-lang-[code-language]'>[inline code]</code>
Highlight the code (in your javascript):
import { highlightAll } from '/path/dist/index.js'
highlightAll();
Auto language detection
import { highlightElement } from '../src/index.js';
import { detectLanguage } from '../src/detect.js';
elm.textContent = code;
highlightElement(elm, detectLanguage(code));
Load custom language
import { loadLanguage } from '../src/index.js';
loadLanguage('language-name', customLanguage);
<link rel="stylesheet" href="https://unpkg.com/@speed-highlight/core/dist/themes/default.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/speed-highlight/core/dist/themes/default.css">
import ... from 'https://unpkg.com/@speed-highlight/core/dist/index.js'
import ... from 'https://cdn.jsdelivr.net/gh/speed-highlight/core/dist/index.js'
Use the deno module
import { setTheme, printHighlight } from 'https://x.nest.land/speed_highlight_js/dist/terminal.js';
await setTheme('[theme-name]')
printHighlight('console.log("hello")', 'js')
Use the npm package
npm i @speed-highlight/core
const { setTheme, printHighlight } = require('@speed-highlight/core/terminal.js');
setTheme('[theme-name]')
printHighlight('console.log("hello")', 'js')
Speed-highlight JS is a lighter and faster version of prism that share a similar API
Remove the prism stylesheet in the head of your html file Clone this repository or use a cdn to load our stylesheet
<head>
- <link href="themes/prism.css" rel="stylesheet" />
+ <link rel="stylesheet" href="https://unpkg.com/@speed-highlight/core/dist/themes/default.css">
</head>
For the script part remove the prism.js script and replace it by a import and a call to highlightAll
<body>
- <script src="prism.js"></script>
+<script>
+ import { highlightAll } from 'https://unpkg.com/@speed-highlight/core/dist/index.js'
+ highlightAll()
+</script>
</body>
If you want to highlight only a specific element you can use the highlightElement
function instead
For the code blocks replace the <pre><code>
by only one <div>
And use shj-lang-
prefix instead of language-
for the class property
-<pre><code class="language-css">p { color: red }</code></pre>
+<div class="shj-lang-css">p { color: red }</div>
And for inline code block you just have to change the class property
-<code class="language-css">p { color: red }</code>
+<code class="shj-lang-css">p { color: red }</code>
Name | Class name | Support | Language detection |
---|---|---|---|
bash | shj-lang-bash | ✅ | |
brainfuck | shj-lang-bf | increment, operator, print, comment | ❌ |
css | shj-lang-css | comment, str, selector, units, function, ... | ✅ |
csv | shj-lang-csv | punctuation, ... | ❌ |
diff | shj-lang-diff | ✅ | |
git | shj-lang-git | comment, insert, deleted, string, ... | ❌ |
html | shj-lang-html | ✅ | |
http | shj-lang-http | keywork, string, punctuation, variable, version | ✅ |
ini | shj-lang-ini | ❌ | |
javascipt | shj-lang-js | basic syntax, regex, jsdoc, json, template literals | ✅ |
jsdoc | shj-lang-jsdoc | ❌ | |
json | shj-lang-json | string, number, bool, ... | ❌ |
leanpub-md | shj-lang-leanpub-md | ❌ | |
log | shj-lang-log | number, string, comment, errors | ❌ |
lua | shj-lang-lua | ✅ | |
makefile | shj-lang-make | ✅ | |
markdown | shj-lang-md | ✅ | |
perl | shj-lang-pl | ✅ | |
plain | shj-lang-plain | ❌ | |
python | shj-lang-py | ✅ | |
regex | shj-lang-regex | count, set, ... | ❌ |
sql | shj-lang-sql | number, string, function, ... | ✅ |
todo | shj-lang-todo | ❌ | |
toml | shj-lang-toml | comment, table, string, bool, variable | ❌ |
typescript | shj-lang-ts | js syntax, ts keyword, types | ✅ |
uri | shj-lang-uri | ✅ | |
yaml | shj-lang-yaml | comment, numbers, variable, string, bool | ❌ |
docker | shj-lang-docker | ✅ | |
c | shj-lang-c | ✅ | |
xml | shj-lang-xml | ✅ | |
rust | shj-lang-rs | ✅ | |
go | shj-lang-go | ✅ | |
java | shj-lang-java | ✅ | |
asm | shj-lang-asm | ✅ |
A modern theme by default
Name | Terminal | Web |
---|---|---|
default | ✅ | ✅ |
github-dark | ❌ | ✅ |
github-light | ❌ | ✅ |
github-dim | ❌ | ✅ |
atom-dark | ✅ | ✅ |
visual-studio-dark | ❌ | ✅ |
Further in-depth documentation for the API and other topics is in our Wiki and our Documentation
Shj is released under the Creative Commons Zero License. See our LICENSE file for details.
FAQs
🌈 Light, fast, and easy to use, dependencies free javascript syntax highlighter, with automatic language detection
The npm package @speed-highlight/core receives a total of 2,836 weekly downloads. As such, @speed-highlight/core popularity was classified as popular.
We found that @speed-highlight/core demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.