Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dennwc/dom
DOM library for Go and WASM
https://github.com/dennwc/dom
dom golang webassembly
Last synced: about 14 hours ago
JSON representation
DOM library for Go and WASM
- Host: GitHub
- URL: https://github.com/dennwc/dom
- Owner: dennwc
- License: apache-2.0
- Created: 2018-06-30T18:37:35.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-09-26T14:33:41.000Z (over 5 years ago)
- Last Synced: 2025-01-19T18:08:14.998Z (8 days ago)
- Topics: dom, golang, webassembly
- Language: Go
- Size: 167 KB
- Stars: 491
- Watchers: 18
- Forks: 58
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go-extra - dom - 06-30T18:37:35Z|2019-09-26T14:33:41Z| (WebAssembly / Routers)
README
# Go DOM binding (and more) for WebAssembly
This library provides a Go API for different Web APIs for WebAssembly target.
It's in an active development, but an API will be carefully versioned to
avoid breaking users.
Use Go dependency management tools to lock a specific version.More information about Go's WebAssembly support can be found on [Go's WebAssembly wiki page](https://github.com/golang/go/wiki/WebAssembly).
**Features:**
- Better JS API (wrappers for `syscall/js`)
- Basic DOM manipulation, styles, events
- Input elements
- SVG elements and transforms
- `LocalStorage` and `SessionStorage`
- Extension APIs (tested on Chrome):
- Native Messaging
- Bookmarks
- Tabs
- `net`-like library for WebSockets
- Tested with gRPC
- `wasm-server` for fast prototyping## Quickstart
Pull the library and install `wasm-server` (optional):
```
go get -u github.com/dennwc/dom
go install github.com/dennwc/dom/cmd/wasm-server
```Run an example app:
```
cd $GOPATH/src/github.com/dennwc/dom
wasm-server
```Check result: http://localhost:8080/
The source code is recompiled on each page refresh, so feel free to experiment!
# Similar Projects
- [go-js-dom](https://github.com/dominikh/go-js-dom)
# Editor Configuration
If you are using Visual Studio Code, you can use [workspace settings](https://code.visualstudio.com/docs/getstarted/settings#_creating-user-and-workspace-settings) to configure the environment variables for the go tools.
Your settings.json file should look something like this:
```
{
"go.toolsEnvVars": { "GOARCH": "wasm", "GOOS": "js" }
}
```