Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nuxt-community/python-module
Write Nuxt 2 applications using Python! [Experimental]
https://github.com/nuxt-community/python-module
frontend javascripthon metapensiero nuxt nuxt-module nuxtjs python web website
Last synced: 1 day ago
JSON representation
Write Nuxt 2 applications using Python! [Experimental]
- Host: GitHub
- URL: https://github.com/nuxt-community/python-module
- Owner: nuxt-community
- License: mit
- Created: 2018-02-01T08:11:19.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2025-02-08T23:22:46.000Z (10 days ago)
- Last Synced: 2025-02-10T11:08:14.661Z (8 days ago)
- Topics: frontend, javascripthon, metapensiero, nuxt, nuxt-module, nuxtjs, python, web, website
- Language: Vue
- Homepage: https://nuxt-python.surge.sh
- Size: 116 KB
- Stars: 202
- Watchers: 10
- Forks: 12
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# @nuxtjs/python
[data:image/s3,"s3://crabby-images/01f30/01f3057be1b6660abe91820dfe75337984eb5e20" alt="npm (scoped with tag)"](https://npmjs.com/package/@nuxtjs/python)
[data:image/s3,"s3://crabby-images/7806c/7806c869b22b8148c8fd7136bc1b3092c2d4d845" alt="npm"](https://npmjs.com/package/@nuxtjs/python)
[data:image/s3,"s3://crabby-images/5e755/5e7550b9cc833be3f3677668933275315e33e22c" alt="CircleCI"](https://circleci.com/gh/nuxt-community/python-module)
[data:image/s3,"s3://crabby-images/7715f/7715fc29662bfbdf1978bb3a797966e95e5aedf8" alt="Codecov"](https://codecov.io/gh/nuxt-community/python-module)
[data:image/s3,"s3://crabby-images/feeab/feeab5f977156d6414a1dc06498545a0a447a279" alt="Dependencies"](https://david-dm.org/nuxt-community/python-module)
[data:image/s3,"s3://crabby-images/bcd4c/bcd4c48fa08cc64f07bbbb9543f287a88341e1c3" alt="js-standard-style"](http://standardjs.com)> Write Nuxt.js Apps in Python
[📖 **Release Notes**](./CHANGELOG.md)
## Features
- Write Nuxt 2 applications using Python!
- Currently only supports custom Javascripthon but in the future other compilers will also be expected to work.## Try the example
1. Clone this repository and change directory into it
2. Install dependencies:
```
npm install # or use yarnpip install -r requirements.txt
```
3. Run example: `npm run dev`## Setup in your own project
- Add `@nuxtjs/python` dependency using yarn or npm to your project
- Add `@nuxtjs/python` to `modules` section of `nuxt.config.js`
```js
{
modules: [
'@nuxtjs/python'
],
python: {
compiler: 'pj' // default
}
}
```
- In Vue files, Mark your script tags like this: ``.
- You may pass options to py-loader (currently it supports `compiler` parameter)## Choice of Python to Javascript compiler
Compiler default and recommended is **Javascripthon** but it is possible to use other compilers (see below).
- Install the [Javascripthon](https://gitlab.com/metapensiero/metapensiero.pj) Python transpiler. For now **you'll need the master branch** e.g:
```
pip install -e git+https://gitlab.com/metapensiero/metapensiero.pj#egg=javascripthon
```- Note that Javascripthon requires that you have **Python 3.5** (or better).
- Javascripthon supports converting Python import statements to ES6 imports as used in Nuxt. Please note syntax [conversions](https://gitlab.com/metapensiero/metapensiero.pj#import-statements).
- You can pass a `compiler` option to py-loader by using module options or in a `python` section in your `nuxt.config.js` file.
- `Transcrypt` has its own module system so in order to use it, you can use the CommonJS module standard (`require` to import and `module.exports`) and it should work. See the `py-loader` [Vuejs example](https://github.com/martim00/python-webpack-loader/blob/master/examples/vue-demo/src/App.vue).
## Usage
### Using `.vue` files
**TIP** If you use Vim you can get syntax highlighting for HTML, CSS *and* Python by installing [vim-vue](https://github.com/posva/vim-vue) plugin and applying [this patch](https://github.com/posva/vim-vue/pull/97).
`hello.vue`:
```html
<template>
<div>
Nuxt {{ best_lang }}
</div>
</template><script lang="py">
class Component:
def __init__(self):
self['data'] = lambda: { 'best_lang': 'Python' }__default__ = Component()
```
### Using `.py` files for other nuxt files
`store/index.py`
```python
from vuex import Storedef increment(state):
state.counter = state.counter + 1def createStore():
return Store(
state={'counter': 0},
mutations={'increment': increment}
)__default__ = createStore
````pages/counter.vue`
```html
{{ $store.state.counter }}
+1```
👉 For a working example, see [here](./example).
## Development
- Clone this repository
- Install dependencies using `yarn install` or `npm install`
- Start development server using `npm run dev`## License
[MIT License](./LICENSE)
Copyright (c) Sebastian Silva
This module was started from the [module-template](https://github.com/nuxt-community/module-template) by Pooya Parsa and relies heavily on [python-webpack-loader](https://github.com/martim00/python-webpack-loader) by Martim Nascimento and [Javascripthon](https://gitlab.com/metapensiero/metapensiero.pj) by Alberto Berti.