136 lines
7.0 KiB
Markdown
136 lines
7.0 KiB
Markdown
# [<img src="https://katex.org/img/katex-logo-black.svg" width="130" alt="KaTeX">](https://katex.org/)
|
|
|
|
[data:image/s3,"s3://crabby-images/bbbf6/bbbf6e63a89d35b0d88502420e90e1431d663ed4" alt="npm"](https://www.npmjs.com/package/katex)
|
|
[data:image/s3,"s3://crabby-images/c0ae3/c0ae335c28a46fdf42a2ff891e33de1371068750" alt="semantic-release"](https://github.com/semantic-release/semantic-release)
|
|
[data:image/s3,"s3://crabby-images/e72f9/e72f97a4974fb235ba0afc6770929f0fb727c51f" alt="CI"](https://github.com/KaTeX/KaTeX/actions?query=workflow%3ACI)
|
|
[data:image/s3,"s3://crabby-images/1fea8/1fea886daf46fa612232e40bae0dba065341f113" alt="codecov"](https://codecov.io/gh/KaTeX/KaTeX)
|
|
[data:image/s3,"s3://crabby-images/37d3b/37d3bc515b9a44cda8d0a81d20ec8ee6b34a09ba" alt="Discussions"](https://github.com/KaTeX/KaTeX/discussions)
|
|
[data:image/s3,"s3://crabby-images/e0062/e006246cafc7dab759f40786dd34c444aed1f2da" alt="jsDelivr"](https://www.jsdelivr.com/package/npm/katex)
|
|
data:image/s3,"s3://crabby-images/99f99/99f99451fe8e0ff2c21fe39d8b5cccc5c5afdcab" alt="katex.min.js size"
|
|
[data:image/s3,"s3://crabby-images/e31be/e31be3b62d29d9f48a42c602077e901cc7fe4c9b" alt="Gitpod ready-to-code"](https://gitpod.io/#https://github.com/KaTeX/KaTeX)
|
|
[data:image/s3,"s3://crabby-images/ca6b8/ca6b89e1a7f0d7903c800db5e2c1c8280f401ddb" alt="Financial Contributors on Open Collective"](https://opencollective.com/katex)
|
|
|
|
KaTeX is a fast, easy-to-use JavaScript library for TeX math rendering on the web.
|
|
|
|
- **Fast:** KaTeX renders its math synchronously and doesn't need to reflow the page. See how it compares to a competitor in [this speed test](https://www.intmath.com/cg5/katex-mathjax-comparison.php).
|
|
- **Print quality:** KaTeX's layout is based on Donald Knuth's TeX, the gold standard for math typesetting.
|
|
- **Self contained:** KaTeX has no dependencies and can easily be bundled with your website resources.
|
|
- **Server side rendering:** KaTeX produces the same output regardless of browser or environment, so you can pre-render expressions using Node.js and send them as plain HTML.
|
|
|
|
KaTeX is compatible with all major browsers, including Chrome, Safari, Firefox, Opera, Edge, and IE 11.
|
|
|
|
KaTeX supports much (but not all) of LaTeX and many LaTeX packages. See the [list of supported functions](https://katex.org/docs/supported.html).
|
|
|
|
Try out KaTeX [on the demo page](https://katex.org/#demo)!
|
|
|
|
## Getting started
|
|
|
|
### Starter template
|
|
|
|
```html
|
|
<!DOCTYPE html>
|
|
<!-- KaTeX requires the use of the HTML5 doctype. Without it, KaTeX may not render properly -->
|
|
<html>
|
|
<head>
|
|
<link
|
|
rel="stylesheet"
|
|
href="https://cdn.jsdelivr.net/npm/katex@0.16.2/dist/katex.min.css"
|
|
integrity="sha384-bYdxxUwYipFNohQlHt0bjN/LCpueqWz13HufFEV1SUatKs1cm4L6fFgCi1jT643X"
|
|
crossorigin="anonymous"
|
|
/>
|
|
|
|
<!-- The loading of KaTeX is deferred to speed up page rendering -->
|
|
<script
|
|
defer
|
|
src="https://cdn.jsdelivr.net/npm/katex@0.16.2/dist/katex.min.js"
|
|
integrity="sha384-Qsn9KnoKISj6dI8g7p1HBlNpVx0I8p1SvlwOldgi3IorMle61nQy4zEahWYtljaz"
|
|
crossorigin="anonymous"
|
|
></script>
|
|
|
|
<!-- To automatically render math in text elements, include the auto-render extension: -->
|
|
<script
|
|
defer
|
|
src="https://cdn.jsdelivr.net/npm/katex@0.16.2/dist/contrib/auto-render.min.js"
|
|
integrity="sha384-+VBxd3r6XgURycqtZ117nYw44OOcIax56Z4dCRWbxyPt0Koah1uHoK0o4+/RRE05"
|
|
crossorigin="anonymous"
|
|
onload="renderMathInElement(document.body);"
|
|
></script>
|
|
</head>
|
|
...
|
|
</html>
|
|
```
|
|
|
|
You can also [download KaTeX](https://github.com/KaTeX/KaTeX/releases) and host it yourself.
|
|
|
|
For details on how to configure auto-render extension, refer to [the documentation](https://katex.org/docs/autorender.html).
|
|
|
|
### API
|
|
|
|
Call `katex.render` to render a TeX expression directly into a DOM element.
|
|
For example:
|
|
|
|
```js
|
|
katex.render("c = \\pm\\sqrt{a^2 + b^2}", element, {
|
|
throwOnError: false,
|
|
});
|
|
```
|
|
|
|
Call `katex.renderToString` to generate an HTML string of the rendered math,
|
|
e.g., for server-side rendering. For example:
|
|
|
|
```js
|
|
var html = katex.renderToString("c = \\pm\\sqrt{a^2 + b^2}", {
|
|
throwOnError: false,
|
|
});
|
|
// '<span class="katex">...</span>'
|
|
```
|
|
|
|
Make sure to include the CSS and font files in both cases.
|
|
If you are doing all rendering on the server, there is no need to include the
|
|
JavaScript on the client.
|
|
|
|
The examples above use the `throwOnError: false` option, which renders invalid
|
|
inputs as the TeX source code in red (by default), with the error message as
|
|
hover text. For other available options, see the
|
|
[API documentation](https://katex.org/docs/api.html),
|
|
[options documentation](https://katex.org/docs/options.html), and
|
|
[handling errors documentation](https://katex.org/docs/error.html).
|
|
|
|
## Demo and Documentation
|
|
|
|
Learn more about using KaTeX [on the website](https://katex.org)!
|
|
|
|
## Contributors
|
|
|
|
### Code Contributors
|
|
|
|
This project exists thanks to all the people who contribute code. If you'd like to help, see [our guide to contributing code](CONTRIBUTING.md).
|
|
<a href="https://github.com/KaTeX/KaTeX/graphs/contributors"><img src="https://contributors-svg.opencollective.com/katex/contributors.svg?width=890&button=false" alt="Code contributors" /></a>
|
|
|
|
### Financial Contributors
|
|
|
|
Become a financial contributor and help us sustain our community.
|
|
|
|
#### Individuals
|
|
|
|
<a href="https://opencollective.com/katex"><img src="https://opencollective.com/katex/individuals.svg?width=890" alt="Contribute on Open Collective"></a>
|
|
|
|
#### Organizations
|
|
|
|
Support this project with your organization. Your logo will show up here with a link to your website.
|
|
|
|
<a href="https://opencollective.com/katex/organization/0/website"><img src="https://opencollective.com/katex/organization/0/avatar.svg" alt="Organization 1"></a>
|
|
<a href="https://opencollective.com/katex/organization/1/website"><img src="https://opencollective.com/katex/organization/1/avatar.svg" alt="Organization 2"></a>
|
|
<a href="https://opencollective.com/katex/organization/2/website"><img src="https://opencollective.com/katex/organization/2/avatar.svg" alt="Organization 3"></a>
|
|
<a href="https://opencollective.com/katex/organization/3/website"><img src="https://opencollective.com/katex/organization/3/avatar.svg" alt="Organization 4"></a>
|
|
<a href="https://opencollective.com/katex/organization/4/website"><img src="https://opencollective.com/katex/organization/4/avatar.svg" alt="Organization 5"></a>
|
|
<a href="https://opencollective.com/katex/organization/5/website"><img src="https://opencollective.com/katex/organization/5/avatar.svg" alt="Organization 6"></a>
|
|
<a href="https://opencollective.com/katex/organization/6/website"><img src="https://opencollective.com/katex/organization/6/avatar.svg" alt="Organization 7"></a>
|
|
<a href="https://opencollective.com/katex/organization/7/website"><img src="https://opencollective.com/katex/organization/7/avatar.svg" alt="Organization 8"></a>
|
|
<a href="https://opencollective.com/katex/organization/8/website"><img src="https://opencollective.com/katex/organization/8/avatar.svg" alt="Organization 9"></a>
|
|
<a href="https://opencollective.com/katex/organization/9/website"><img src="https://opencollective.com/katex/organization/9/avatar.svg" alt="Organization 10"></a>
|
|
|
|
## License
|
|
|
|
KaTeX is licensed under the [MIT License](https://opensource.org/licenses/MIT).
|