Most playgrounds (like Go or MongoDB) run code on the Codapi server.
But there are some playgrounds that work completely in the browser, no Codapi server required.
Note that WASI-based playgrounds (engine
= wasi
in the examples below) require two additional scripts besides the usual snippet.js
:
<script src="https://unpkg.com/@antonz/runno@0.6.1/dist/runno.js"></script>
<script src="https://unpkg.com/@antonz/codapi@0.19.10/dist/engine/wasi.js"></script>
<script src="https://unpkg.com/@antonz/codapi@0.19.10/dist/snippet.js"></script>
Executes the code using the AsyncFunction.
<pre><code>
const msg = "Hello, World!"
console.log(msg)
</code></pre>
<codapi-snippet engine="browser" sandbox="javascript" editor="basic"></codapi-snippet>
Executes the code using the Fetch API.
<pre><code>
POST https://httpbingo.org/dump/request
content-type: application/json
{
"message": "hello"
}
</code></pre>
<codapi-snippet engine="browser" sandbox="fetch" editor="basic"></codapi-snippet>
Executes the code using the Lua WASI runtime (330 KB).
<pre><code>
local msg = "Hello, World!"
print(msg)
</code></pre>
<codapi-snippet engine="wasi" sandbox="lua" editor="basic"></codapi-snippet>
Executes the code using the PHP WASI runtime (13.2 MB).
<pre><code>
<?php
$msg = "Hello, World!";
echo $msg;
?>
</code></pre>
<codapi-snippet engine="wasi" sandbox="php" editor="basic"></codapi-snippet>
Executes the code using the PGlite runtime (12 MB).
<pre><code>
create table data(message text);
insert into data values ('Hello, World!');
select * from data;
</code></pre>
<codapi-snippet engine="pglite" sandbox="postgres" editor="basic" output-mode="table">
</codapi-snippet>
Note that this playground requires additional scripts besides the usual snippet.js
:
<script type="module">
import { PGlite } from "https://cdn.jsdelivr.net/npm/@electric-sql/pglite/dist/index.js";
window.PGlite = PGlite;
</script>
<script src="https://unpkg.com/@antonz/codapi@0.19.10/dist/engine/pglite.js"></script>
<script src="https://unpkg.com/@antonz/codapi@0.19.10/dist/snippet.js"></script>
Executes the code using the Python WASI runtime (26.3 MB).
<pre><code>
msg = "Hello, World!"
print(msg)
</code></pre>
<codapi-snippet engine="wasi" sandbox="python" editor="basic"></codapi-snippet>
Executes the code using the Ruby WASI runtime (24.5 MB).
<pre><code>
msg = "Hello, World!"
puts msg
</code></pre>
<codapi-snippet engine="wasi" sandbox="ruby" editor="basic"></codapi-snippet>
Executes the code using the SQLite WASI runtime (2.1 MB).
<pre><code>
select "Hello, World!" as message;
</code></pre>
<codapi-snippet engine="wasi" sandbox="sqlite" editor="basic"></codapi-snippet>