Pythonic Vue.js
Project description
RE:Newal!
- changed project style more silimar to vuejs 2.x template
- use vue file by vbuild
Install
using pip
pip install pyvuejs
Usage
start server by main.py file in project directory
python ./main.py
serve configurations
config update by Vue.use in main.py
- parameters
- host[str]: host url of server(default: "0.0.0.0")
- port[int]: port number of server(default: 47372)
- debug[bool]: flag of show bottle log(default: True)
- open_webbrowser[bool]: flag of open browser when start(default: True)
Vue.use(
VueConfig(
host = "0.0.0.0",
port = 47372,
debug = True,
open_webbrowser = True
)
)
view/component editing guide
same as vue.js, can support by linting
- for now, template, style, script blocks are supported
- more information on vbuild and vbuild python document
<!-- template block -->
<template>
<div>
<label>{{ count }}</label>
<div>
<button style="margin-right:10px;" v-on:click="up_count">up</button>
<button v-on:click="down_count">down</button>
</div>
</div>
</template>
<!-- style block -->
<style scoped>
button {
width: 80px;
}
</style>
<!-- script block -->
<script lang="python">
class Component:
def __init__(self):
self.count = 0
def up_count(self):
self.count += 1
def down_count(self):
if self.count > 0:
self.count -= 1
</script>
use view/component
just call name in other view
<template>
<div id="app">
<div id="nav">
<router-link to="/Home">Home</router-link> |
<router-link to="/About">About</router-link> |
<router-link to="/Counter">Counter</router-link>
</div>
<router-view/>
</div>
</template>
events mapping
define map class and map functions in each file of maps
- if debug option in config, functions can be reached by "GET" and "POST". else, "POST" only
from pyvuejs import VueMap
class Counter(VueMap):
count = 0
@VueMap.map
def get_count(self):
return self.count
@VueMap.map
def up_count(self):
self.count += 1
@VueMap.map
def down_count(self):
if self.count > 0:
self.count -= 1
routes
define route path and component in router.py
from pyvuejs import Vue, VueRouter
Vue.use(VueRouter([
{
"path": "/About",
"component": "About"
},
{
"path": "/Home",
"component": "Home"
},
{
"path": "/Counter",
"component": "Counter"
}
]))
Todo
- routes
License
pyvuejs is MIT license
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pyvuejs-2.0.5.post2.tar.gz
(77.7 kB
view details)
Built Distribution
File details
Details for the file pyvuejs-2.0.5.post2.tar.gz
.
File metadata
- Download URL: pyvuejs-2.0.5.post2.tar.gz
- Upload date:
- Size: 77.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9520b2518aaffdf4ff2f362a1e91f97919a295ceef40cae61e1e593806f7c4ed |
|
MD5 | de2235fc9593dc6a86f724a02302049a |
|
BLAKE2b-256 | 42e429bdb8c3f41280c561b78775729ce4066697d6662897ab11eca73afe31dc |
File details
Details for the file pyvuejs-2.0.5.post2-py3-none-any.whl
.
File metadata
- Download URL: pyvuejs-2.0.5.post2-py3-none-any.whl
- Upload date:
- Size: 79.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3c5aec58a10ab045b442b9407762cccc56c3b0cb39815337ce0bf3f262a00a27 |
|
MD5 | a08f78b8f94eef2ef642f0f8e8e1e138 |
|
BLAKE2b-256 | e98cd993d55f1efa7148407656902245698c01fb9fa56efe89a26d971861e726 |