Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/barata-ribeiro/vite-vanilla-js-template
ViteJS starter template for vanilla JavaScript with some basic dependencies.
https://github.com/barata-ribeiro/vite-vanilla-js-template
autoprefixer boilerplate boilerplate-template css-nano css-reset eslint javascript open-source postcss prettier scaffold-template template vanilla-javascript vite vite-template vitejs vitejs-template
Last synced: about 2 months ago
JSON representation
ViteJS starter template for vanilla JavaScript with some basic dependencies.
- Host: GitHub
- URL: https://github.com/barata-ribeiro/vite-vanilla-js-template
- Owner: Barata-Ribeiro
- License: mit
- Created: 2023-06-18T14:46:54.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-24T23:06:35.000Z (3 months ago)
- Last Synced: 2024-11-07T08:42:46.712Z (3 months ago)
- Topics: autoprefixer, boilerplate, boilerplate-template, css-nano, css-reset, eslint, javascript, open-source, postcss, prettier, scaffold-template, template, vanilla-javascript, vite, vite-template, vitejs, vitejs-template
- Language: CSS
- Homepage:
- Size: 932 KB
- Stars: 40
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Vite Vanilla JS Template
![screenshot](/public/screenshot.png)
Initially built for personal use, I created this template for starting a new project with Vite.js and Vanilla Javascript. It is already set up with standard development tools like ESLint and Prettier for easy code formatting and linting, with Vite for a robust, modern build process.
## Dependencies
This template uses the following dependencies:
- **[Vite](https://vitejs.dev/):** A next-generation frontend build tool that offers a fast dev server and optimized builds.
- **[ESLint](https://eslint.org/):** An open-source JavaScript linting utility that helps maintain a consistent code style.
- **[Prettier](https://prettier.io/):** An opinionated code formatter that enforces a consistent style across your project.
- **[eslint-config-airbnb-base](https://www.npmjs.com/package/eslint-config-airbnb-base) and [eslint-config-prettier](https://www.npmjs.com/package/eslint-config-prettier):** ESLint configurations adhering to Airbnb's base JS style guide and disabling stylistic rules that might conflict with Prettier.
- **[eslint-plugin-import](https://www.npmjs.com/package/eslint-plugin-import) and [eslint-plugin-prettier](https://www.npmjs.com/package/eslint-plugin-prettier):** ESLint plugins that enforce ES2015+ import/export syntax and integrate Prettier with ESLint.
- **[autoprefixer](https://www.npmjs.com/package/autoprefixer) and [postcss](https://postcss.org/):** Autoprefixer automatically adds vendor prefixes to CSS, while PostCSS provides a way to transform CSS with JavaScript.
- **[cssnano](https://cssnano.github.io/cssnano/):** A tool that helps to compress and optimize CSS files.
- **[postcss-nesting](https://www.npmjs.com/package/postcss-nesting):** A PostCSS plugin that allows you to use modern CSS Nesting in your stylesheets.
- **[vite-plugin-eslint](https://www.npmjs.com/package/vite-plugin-eslint):** Integrates ESLint into the Vite build process for on-the-fly linting.
- **[the-new-css-reset](https://elad2412.github.io/the-new-css-reset/):** A modern, CSS reset for your styles.## Cloning
1. To start using this template, clone the repository with this command:
```bash
git clone https://github.com/Barata-Ribeiro/vite-vanilla-js-template.git
```2. Then proceed to the folder and install dependencies:
```bash
cd vite-vanilla-js-template
npm install
```**or**
```bash
npm install -g degit # if you don't have degit installed...#degit documentation at: https://github.com/Rich-Harris/degit
```1. Use 'degit' to create a folder project using this template:
```bash
degit Barata-Ribeiro/vite-vanilla-js-template your-project-name
```2. Then proceed to the folder and install dependencies:
```bash
cd your-project-name
npm install
```## Post-Cloning Steps
After cloning the template, make sure to clean up and update the following:
1. Remove the .git directory and run `git init` to clean the commit history.
2. Clean up the README.md file.
3. Adapt the LICENSE file to your project.
4. Delete `public/vite.svg`, `public/screenshot`, `src/assets/images/javascript.svg`, and `src/assets/images/vite.svg`.
5. Delete the content from `src/styles/style.css`.
6. In the `src/js/main.js` file, leave only these import statements: `import "../../styles/style.css";` and `import "the-new-css-reset/css/reset.css";`.
7. Adapt the `package.json` file with your project's own information.
8. Delete the .github folder.## Scripts
Use the following scripts for your development workflow:
```bash
# Start the development server
npm run dev# Checks your code for any linting errors
npm run lint# Tries to automatically fix any linting errors present in your code
npm run lint:fix# Formats your code in a consistent, predefined style using Prettier
npm run format# Build for production
npm run build# Preview the build
npm run preview# Build and preview the project
npm run buildpreview
```## Folder Structure
This is the structure of the project:
```plaintext
/
├── .github # Github actions and workflows
├── node_modules # Node.js dependencies for the project.
├── public # Public assets and resources
├── src # Source code
│ ├── assets # General assets for your project
│ │ ├── images # Store your images here
│ ├── js # Javascript files of your project
│ ├── styles # CSS styles for your project
├── .editorconfig # Configuration for the EditorConfig plugin
├── .eslintignore # Files to be ignored by ESLint
├── .eslintrc.json # Configuration for ESLint
├── .gitignore # Files and folders to be ignored by Git
├── .prettierignore # Files to be ignored by Prettier
├── .prettierrc # Configuration for Prettier
├── index.html # The HTML file for your project
├── LICENSE # The license for your project
├── package-lock.json # Lockfile for your project's dependencies
├── package.json # Defines your project and its dependencies
├── postcss.config.cjs # Configuration for PostCSS
├── README.md # This file
├── vite.config.js # Configuration for Vite
```## License
This template was created under the [MIT License](LICENSE.md).
**Happy coding!** 👨💻