• Stars
    star
    231
  • Rank 173,434 (Top 4 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created about 7 years ago
  • Updated almost 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A parcel plugin that enables svelte support

parcel-plugin-svelte

Build Status

A parcel plugin that enables svelte support

Getting Started

Install dependencies

yarn add svelte parcel-bundler parcel-plugin-svelte @babel/polyfill -D

Update the package.json

Update your package.json to contain these scripts (for more information on these commands, see: https://v1.parceljs.org/cli.html):

{
  "scripts": {
    "start": "parcel index.html",
    "build": "parcel build index.html"
  }
}

Create the files

Create an html file that will be used as the entrypoint, name it index.html:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Parcel Plugin Svelte Example</title>
  </head>
  <body>
    <div id="demo"></div>

    <!-- This script tag points to the source of the JS file we want to load and bundle -->
    <script src="main.js"></script>
  </body>
</html>

Create a simple JavaScript file named main.js:

import '@babel/polyfill';
import App from './App.svelte';

new App({
  target: document.getElementById('demo'),
  props: {
    name: 'world'
  }
});

Create a Svelte file named App.svelte:

<p>
  Hello { name }, the time is <span class="the-time">{ hours }:{ minutes }:{ seconds }</span>
</p>

<style>
  .the-time {
    font-weight: bold;
  }
</style>

<script>
  import { onMount } from 'svelte';

  export let name = 'Anonymous';
  let time = new Date();

  onMount(() => {
    const timer = setInterval(() => {
      time = new Date();
    }, 1000)

    return () => {
      clearInterval(timer);
    }
  })

  let hours, minutes, seconds;

  $: {
    hours = time.getHours();
    minutes = time.getMinutes();
    seconds = time.getSeconds();
  }
</script>

Further reading

To continue your journey into Svelte and Parcel please have a look at their documentation:

for configuring this plugin, please read #Configuration

Configuration

The default configuration should work for most people but for anyone who would like to change the way svelte compiles the files there is the possibility to configure it.

This can be done though a svelte.config.js file, .svelterc file or svelte field in package.json.

For documentation on which parameters you can set and use look at the official svelte docs.

// Used by svelte.compilerOptions
compilerOptions: {
  ...
},
// Used by svelte.preprocess
preprocess: {
  ...
}

Note: the use of compiler property will be deprecated on the next major version, you should use thecompilerOptions property instead.

CSS CompilerOptions

If you set compilerOptions.css to false, CSS will be bundled in a separate file. It also enables post-transformations provided by Parcel such as PostCSS and file resolution for url().

How does it work?

If you want to know how it works have a look at my article about this plugin, might help if you wanna fix a bug or write your own parcel-plugin.

Any more questions?

Any more questions about how the plugin works internally or how to use it? Feel free to open an issue in the repository.

License

This project is licensed under the MIT License

More Repositories

1

parcel-plugin-imagemin

Parcel image minification plugin
JavaScript
129
star
2

blazingly-ssr

A blazing fast server side rendering & project optimiser cli tool using Parcel (POC/Experiment)
JavaScript
41
star
3

stylish-components

A component styling library with minimalism and performance in mind
JavaScript
18
star
4

tiny-benchy

TypeScript
15
star
5

vscode-pigments

Preview colors used inside the editor instantly
TypeScript
15
star
6

Angular-Parcel-Boilerplate

Parcel template for using Angular.io
JavaScript
15
star
7

fswatcher-child

An error prone wrapper over chokidars fswatcher for better performance and stability
JavaScript
7
star
8

triage-bot

Automatically labels issues according to globs
TypeScript
4
star
9

sourcemap-visualiser

A user friendly sourcemap visualiser built for Parcel
TypeScript
4
star
10

swc-wasm

JavaScript
3
star
11

simple-react-form-validator

A lightweight helper component for managing form validation
JavaScript
2
star
12

Loner-pong

Simple 3D javascript experiment (Pong)
JavaScript
1
star
13

parcel-plugin-web-ui

CSS
1
star
14

jsontotypescript

a json to typescript class (template) convertor
JavaScript
1
star
15

bluereceipt-challenge

TypeScript
1
star
16

Maltrail

A highly customisable intrusion detection system, with various built in lists(trails) for known attacks and attackers
Python
1
star
17

import-grapher

Generates a dependency tree based on a js entrypoint
JavaScript
1
star
18

graphql-docs

An on the fly documentation generation web-app for GraphQL API's
TypeScript
1
star
19

productivity-tracker

Small project to track hours spent on one of your hobbies/ambitions/goals/...
HTML
1
star