Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nicolo-ribaudo/vue-extract-loader
A Webpack loader which extracts a single block from Vue single-file components
https://github.com/nicolo-ribaudo/vue-extract-loader
single-file-component vue vue-loader vue-webpack webpack webpack-loader webpack-vue
Last synced: 3 months ago
JSON representation
A Webpack loader which extracts a single block from Vue single-file components
- Host: GitHub
- URL: https://github.com/nicolo-ribaudo/vue-extract-loader
- Owner: nicolo-ribaudo
- Created: 2017-05-22T21:40:55.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-05-29T20:06:05.000Z (over 7 years ago)
- Last Synced: 2024-05-01T21:19:38.219Z (8 months ago)
- Topics: single-file-component, vue, vue-loader, vue-webpack, webpack, webpack-loader, webpack-vue
- Language: JavaScript
- Homepage:
- Size: 19.5 KB
- Stars: 5
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# vue-extraxt-loader
> A [Webpack](https://webpack.js.org) loader which extracts a single block from Vue single-file components.**What is the difference with [vue-loader](https://github.com/vuejs/vue-loader)?**
Beside importing components, vue-loader can also load custom blocks. But you can't import only a custom block: vue-loader imports the whole file, and attaches the custom block to the component using an user-defined loader.
On the other hand, vue-extraxt-loader imports just the wanted block, ignoring the other parts of the file: this can be useful, for example, for importing a `` block from a testing framework.
## Install
You can install this package either using yarn or npm:
```
yarn add --dev vue-extraxt-loader# or
npm install -D vue-extraxt-loader
```## Usage
You can either use this loader inline, or add it to your `webpack.config.js` file.
> ⚠️**WARNING**
>
> If `vue-extract-loader` and `vue-loader` are applied to the same import request, `vue-loader` gets ignored.
> This behavior can be useful if you set `vue-loader` for every `.vue` file, but you should ensure that `vue-extract-loader` doesn't get applied to too much paths.
>
> For this reason, it is recommended to use `vue-extract-loader` inline.### Options
| Option | Required | Description |
| ------------- |:-------------:| ----- |
| `block` | ✔️ | The name of the tag to import |### Examples and use cases
01. [Basic](./examples/01-base/) - A basic example which shows how to use this loader.
02. [vue-play](./examples/02-play) - Shows how to define an alias for the loader, so that you can `import "vue-play-loader!./component.vue"`.
03. [Testing](./examples/03-play) - Sets the loader in `webpack.config.js`, without applying it to too much paths. (see [the previous warning](#warning-inline-loader))
04. [Src import](./examples/04-src-import/) - This loader also works if the custom block specifies its value using the `src` attribute.
05. [vue-play chunks splitting](./examples/05-play-chunks) - Like 02, but the component and the play block are in two different chunks.