md2vue-loader
v1.0.6
Published
A loader to parse markdown file to a vue template file. The loader will parse the marked file to a template for [vue-loader](https://vue-loader.vuejs.org/) to parse.
Downloads
22
Maintainers
Readme
Md2Vue-loader
A loader to parse markdown file to a vue template file. The loader will parse the marked file to a template for vue-loader to parse.
You can also to use options.directOutput
to output direct Vue file without template.
Usage
- Install md2vue-loaer
npm install --save-dev md2vue-loader
- Config the webpack config file to parse markdown file.
module: {
rules: [
test: /\.md$/,
loader: ['vue-loader', 'md2vue-loader']
]
}
API
Loader options
- template: the template file to generator.
Example:
module: {
rules: [
test: /\.md$/,
loader: [
'vue-loader',
{
loader: 'md2vue-loader',
options: {
template: 'path/to/template-file',
headingId: false, // heading render id. [https://github.com/chjj/marked/issues/806]
directOutput: false
}
}
]
]
}
Example
Let's look at a example.
input file source
## Usage
Use the button component
```html
<h2>This is the Vue Component!</h2>
<t-button></t-button>
```
````javascript
import TButton from 'components/button'
export default {
components: {
TButton
}
}
````
```css
button {
color: red;
}
```
output source
<template>
<div class="t-component-demo">
<div class="demo-box">
<h2>This is the Vue Component!</h2>
<t-button></t-button>
</div>
<div class="md-box">
<h2 id="usage">Usage</h2>
<p>Use the button component</p>
</div>
<div class="code-box">
<pre>
<code>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>template</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>h2</span><span class="token punctuation">></span></span>This is the Vue Component!<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>h2</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>t-button</span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>t-button</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>template</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>script</span><span class="token punctuation">></span></span><span class="token script language-javascript">
<span class="token keyword">import</span> TButton <span class="token keyword">from</span> <span class="token string">'components/button'</span>
<span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
components<span class="token punctuation">:</span> <span class="token punctuation">{</span>
TButton
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>script</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>style</span><span class="token punctuation">></span></span><span class="token style language-css">
<span class="token selector">button</span> <span class="token punctuation">{</span>
<span class="token property">color</span><span class="token punctuation">:</span> red<span class="token punctuation">;</span>
<span class="token punctuation">}</span>
</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>style</span><span class="token punctuation">></span></span>
</code>
</pre>
</div>
</div>
</template>
<script>
import TButton from 'components/button'
export default {
components: {
TButton
}
}
</script>
<style scoped>
button {
color: red;
}
</style>
Todos
- [ ] Multiple Markdown files to loader.
- [ ] Code highlight configurable.
- [ ] id add prefixer