-
Notifications
You must be signed in to change notification settings - Fork 0
/
vue.config.js
109 lines (100 loc) · 3.78 KB
/
vue.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
const path = require('path')
const utils = require('./build/utils')
const MarkdownItContainer = require('markdown-it-container')
const striptags = require('./build/strip-tags')
const md = require('markdown-it')()
const vueMarkdown = {
preprocess: (MarkdownIt, source) => {
MarkdownIt.renderer.rules.table_open = function () {
return '<table class="table">'
}
MarkdownIt.renderer.rules.fence = utils.wrapCustomClass(MarkdownIt.renderer.rules.fence)
// ```html `` 给这种样式加个class hljs
// 但是markdown-it 有个bug fence整合attr的时候直接加载class数组上而不是class的值上
// markdown-it\lib\renderer.js 71行 这么修改可以修复bug
// tmpAttrs[i] += ' ' + options.langPrefix + langName; --> tmpAttrs[i][1] += ' ' + options.langPrefix + langName;
// const fence = MarkdownIt.renderer.rules.fence
// MarkdownIt.renderer.rules.fence = function(...args){
// args[0][args[1]].attrJoin('class', 'hljs')
// var a = fence(...args)
// return a
// }
// ```code`` 给这种样式加个class code_inline
const code_inline = MarkdownIt.renderer.rules.code_inline
MarkdownIt.renderer.rules.code_inline = function(...args){
args[0][args[1]].attrJoin('class', 'code_inline')
return code_inline(...args)
}
return source
},
use: [
[MarkdownItContainer, 'demo', {
validate: params => params.trim().match(/^demo\s*(.*)$/),
render: function(tokens, idx) {
var m = tokens[idx].info.trim().match(/^demo\s*(.*)$/);
if (tokens[idx].nesting === 1) {
var desc = tokens[idx + 2].content;
var content = tokens[idx + 1].content
const html = utils.convertHtml(striptags.strip(tokens[idx + 1].content, 'script'))
var script = striptags.fetch(content, 'script');
// let demoComponentContent = striptags.genInlineComponentText(html, script);
// 移除描述,防止被添加到代码块
tokens[idx + 2].children = [];
console.log(content)
return `<demo-block>
<div slot="source">${content}</div>
<div slot="highlight">`;
}
return '</div></demo-block>\n';
}
}]
]
}
const isMinify = process.argv.indexOf('-p') !== -1;
module.exports = {
// 修改 pages 入口
pages: {
index: {
entry: 'doc/main.ts', // 入口
template: 'public/index.html', // 模板
filename: 'index.html', // 输出文件
},
},
configureWebpack: {
output: {
libraryExport: ['default']
}
},
// 扩展 webpack 配置
chainWebpack: config => {
// @ 默认指向 src 目录,这里要改成 doc
// 另外也可以新增一个 ~ 指向 package
config.resolve.alias
.set('@', path.resolve('doc'))
.set('~', path.resolve('package'))
// 把 doc 和 package 加入编译,因为新增的文件默认是不被 webpack 处理的
config.module
.rule('md')
.test(/\.md/)
.use('vue-loader')
// .loader('./md-loader/index.js')
.loader('vue-loader')
.end()
.use('vue-markdown-loader')
.loader('vue-markdown-loader/lib/markdown-compiler')
.options({
raw: true,
...vueMarkdown
})
config.module
.rule('ts')
.include.add(/doc/).end()
.include.add(/package/).end()
.use('babel')
.loader('babel-loader')
.tap(options => {
// 修改它的选项...
return options
})
}
}