Vue.js-like без единой строчки js
Игорь Шеко
Web Assembly
WASM
Browser
Божественный JS
$$$
WASM
Поддержка
-
Chrome
-
Firefox
-
Edge
-
Safari ???
https://webkit.org/blog/9672/release-notes-for-safari-technology-preview-97/
JS
Rust
C++
Go
C# ???
???BASIC
GOOS=js GOARCH=wasm go build -o main.wasm main.go
applyFilteFunc := js.FuncOf(applyFilter) //wrapper
js.Global().Set("applyFilter", applyFilteFunc)
Игорь, что ты нагнетаешь?
Они же не могут в DOM
window = js.Global()
doc = window.Get("document")
squaresCanvas = doc.Call("getElementById", "sCanvas")
sctx = squaresCanvas.Call("getContext", "2d")
wordCanvas = doc.Call("getElementById", "wCanvas")
wctx = wordCanvas.Call("getContext", "2d")
width = window.Get("innerWidth").Float()
height = window.Get("innerHeight").Float()
squaresCanvas.Set("width", width)
squaresCanvas.Set("height", height)
<div class="my-first-vugu-comp">
<button @click="data.Toggle()">Test</button>
<div vg-if="data.Show">I am here!</div>
</div>
<style>
.my-first-vugu-comp { background: #eee; }
</style>
<script type="application/x-go">
type RootData struct { Show bool }
func (data *RootData) Toggle() { data.Show = !data.Show }
</script>
VUGU
PLEASE NOTE: This is experimental technology! (read more)
Templates
- vg-if
- vg-for
- vg-html
- Dynamic Attributes
- DOM Events
CSS
- prefix your styles
- Styles are deduplicated
- Styles are inserted in one place at the top of the root component
- not want to use @import to load external style sheets
- dynamic elements are not currently supported in styles
PostCSS не нужон!
<div class="demo">
<div vg-if='data.isLoading'>Loading...</div>
<div vg-if='len(data.bpi.BPI) > 0'>
<div>Updated: <span vg-html='data.bpi.Time.Updated'></span></div>
<ul>
<li vg-for='data.bpi.BPI'>
<span vg-html='key'></span> <span vg-html='fmt.Sprint(value.Symbol, value.RateFloat)'></span>
</li>
</ul>
</div>
<button @click="data.HandleClick(event)">Fetch Bitcoin Price Index</button>
</div>
<script type="application/x-go">
import "encoding/json"
import "net/http"
import "log"
type RootData struct {
bpi bpi
isLoading bool
}
type bpi struct {
Time struct { Updated string `json:"updated"` } `json:"time"`
BPI map[string]struct { Code string `json:"code"`; Symbol string `json:"symbol"`; RateFloat float64 `json:"rate_float"` } `json:"bpi"`
}
func (data *RootData) HandleClick(event *vugu.DOMEvent) {
data.bpi = bpi{}
ee := event.EventEnv()
go func() {
ee.Lock()
data.isLoading = true
ee.UnlockRender()
res, err := http.Get("https://api.coindesk.com/v1/bpi/currentprice.json")
if err != nil {
log.Printf("Error fetch()ing: %v", err)
return
}
defer res.Body.Close()
var newb bpi
err = json.NewDecoder(res.Body).Decode(&newb)
if err != nil {
log.Printf("Error JSON decoding: %v", err)
return
}
ee.Lock()
defer ee.UnlockRender()
data.bpi = newb
data.isLoading = false
}()
}
</script>
Всем спасибо
Игорь Шеко
Lead of the Front-end team @ Voximplant
Vue.js-like без единой строчки js (Golang)
By Igor Sheko
Vue.js-like без единой строчки js (Golang)
- 455