Awesome
<div align="center">V-WebUI
Features 路 Installation 路 Usage 路 Documentation 路 WebUI
</div>Use any web browser or WebView as GUI.
With V in the backend and modern web technologies in the frontend.
Features
- Parent library written in pure C
- Fully Independent (No need for any third-party runtimes)
- Lightweight ~200 Kb & Small memory footprint
- Fast binary communication protocol between WebUI and the browser (Instead of JSON)
- Multi-platform & Multi-Browser
- Using private profile for safety
Installation
v install https://github.com/webui-dev/v-webui
Usage
[!NOTE] It is recommended to use GCC or Clang to compile a WebUI V program. TCC is currently not working due to missing header files. E.g.:
v -cc gcc run .
Example
import vwebui as ui
const html = '<!DOCTYPE html>
<html>
<head>
<script src="webui.js"></script>
<style>
body {
background: linear-gradient(to left, #36265a, #654da9);
color: AliceBlue;
font: 16px sans-serif;
text-align: center;
margin-top: 30px;
}
</style>
</head>
<body>
<h1>Welcome to WebUI!</h1>
<br>
<input type="text" id="name" value="Neo">
<button onclick="handleVResponse();">Call V</button>
<br>
<br>
<div><samp id="greeting"></samp></div>
<script>
async function handleVResponse() {
const inputName = document.getElementById("name");
const result = await webui.greet(inputName.value);
document.getElementById("greeting").innerHTML = result;
}
</script>
</body>
</html>'
fn greet(e &ui.Event) string {
name := e.get_arg[string]() or { panic('expected an argument') }
println('${name} has reached the backend!')
return 'Hello ${name} 馃悋'
}
fn main() {
mut w := ui.new_window()
w.bind('greet', greet)
w.show(html)!
ui.wait()
}
Find more examples in the examples/
directory.
Documentation
- Online Documentation (WIP)
[!TIP] Until our online documentation is finished, you can refer to
src/lib.v
or use V's built-inv doc -comments vwebui
in the terminal for the latest overview of exported functions.
-
To use WebUI's debug build in your V-WebUI application, add the
-d debug
flag. E.g.:v -d webui_log run examples/call_v_from_js.v
-
Run tests locally:
VJOBS=1 v -stats test tests/
Supported Web Browsers
Browser | Windows | macOS | Linux |
---|---|---|---|
Mozilla Firefox | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Google Chrome | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Microsoft Edge | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Chromium | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Yandex | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Brave | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Vivaldi | 鉁旓笍 | 鉁旓笍 | 鉁旓笍 |
Epic | 鉁旓笍 | 鉁旓笍 | not available |
Apple Safari | not available | coming soon | not available |
Opera | coming soon | coming soon | coming soon |
License
Licensed under the MIT License.