Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bb010g/viperhtml-template
https://github.com/bb010g/viperhtml-template
Last synced: 21 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/bb010g/viperhtml-template
- Owner: bb010g
- Created: 2017-11-12T09:12:53.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2017-11-12T09:20:02.000Z (about 7 years ago)
- Last Synced: 2024-10-31T15:12:38.302Z (2 months ago)
- Language: JavaScript
- Size: 187 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# create-viperhtml-app
[![donate](https://img.shields.io/badge/$-donate-ff69b4.svg?maxAge=2592000&style=flat)](https://github.com/WebReflection/donate)
A basic [viperHTML](https://github.com/WebReflection/viperHTML) + [hyperHTML](https://github.com/WebReflection/hyperHTML) setup based on [Webpack](https://webpack.js.org/) and with native subclassing capabilities, including Custom Elements.
Based on [WebReflection's original](https://github.com/WebReflection/create-viperhtml-app).
### How To Start
`npm install` to bring all dependencies in, then `npm run build` whenever you change assets or simply `npm run watch` to automatically update all new files.
To test the example page, just run the usual `npm start`.
### Folders Structure
* **cdn** contains all optimized on-demand static assets. It's automatically managed, nothing to do there.
* **public** is the actual public site content. It contains few static assets but also JS bundles. You can add CSS bundles too (coming soon).
* **dist** is the bundled server content.
* **src** is where the actual app code is defined, it has at least these subfolders: **client**, for the browser related client-side code, **server**, for the HTTP based back-end service, and **view**, for the external files used either on the client, on the server, or in both, to generate the whole page, or partial content.You can **surf each folder inside [./src](./src/)** one to know more about each role.
#### F.A.Q.
* can I use _express_ or others? Sure you can, this is just a basic setup.
* how to cleanup _tinyCDN_ cached content? You can simply `rm -rf cdn/*` or `npm run clean` before re-deploying. _tinyCDN_ gives for granted if a file name is the same, the content must be too. It really works in that sense.
* how come the example page shows with _hiccups_? It's a demonstration that _viperHTML_ can also render partial asynchronous chunks, no matter in which order these are resolved. You can remove the array of promises from the `body` info of the server `model` and re-test anything you'd like to