相关连接html
完整的Vue组件代码以及完整的文档,仅适用于我的参考学习:vue
文档预览地址:预览连接
使用VuePress
编辑文档的代码访问:组件文档
完整代码:组件代码
Vue组件开发webpack
这篇文章主要是记录本身在使用VuePress过程当中所遇到的问题以及如何一步一步的解决问题。git
安装vuepress前,请确保你的 Node.js 版本 >= 8github
# 安装 yarn global add vuepress 或者:npm install -g vuepress # 新建一个 markdown 文件 echo '# Hello VuePress!' > README.md # 开始写做 vuepress dev . # 构建静态文件 vuepress build .
注意 :vuepress dev .
和vuepress build .
后面的.
。web
# 将 vuepress 做为一个本地依赖安装 yarn add -D vuepress 或者:npm install -D vuepress # 新建一个 docs 文件夹 mkdir docs # 新建一个 markdown 文件 echo '# Hello VuePress!' > docs/README.md # 开始写做 npx vuepress dev docs
接着,在 package.json
里加一些脚本:npm
{ "scripts": { "docs:dev": "vuepress dev docs", "docs:build": "vuepress build docs" } }
开始写做json
yarn docs:dev 或者:npm run docs:dev
第一个坑:个人项目就是依赖webpack 3.6.0
同时也是用npm安装依赖,而后继续使用npm安装vuepress,而后执行npx vuepress dev docs
的时候报错了,上网查了很久也没有解决问题,最后使用yarn安装vuepress成功了。segmentfault
若是你的现有项目依赖了 webpack 3.x,推荐使用 yarn而不是 npm 来安装 vuepress。api
要生成静态的 HTML 文件,运行:
yarn docs:build 或者:npm run docs:build
默认状况下,文件将会被生成在 .vuepress/dist
,也能够经过 .vuepress/config.js
中的 dest
字段来修改.
以上步骤都成功之后,就能够在浏览器总看到页面了,接下来就是对页面进行布局
本文是根据VuePress默认主题配置
在docs文件夹下建立.vuepress文件夹
和README.md文件
。(若是以及有了就不要再新建)
根目录下的README.md文件能够看成首页,在文件中加入下面文字:
--- home: true actionText: 快速上手 → actionLink: /guide/install/install ---
能够根据本身的须要添加、删除、修改,这就完成了首页的布局
actionLink: /guide/install/install
就是首页后要显示的下一个页面
接下来在docs文件夹中建立guide文件夹
(根据本身的须要命名)。这个文件夹中放的是markdown
文件,每个markdown
文件对应一个页面。至于页面之间的跳转和页面导航栏和侧边栏布局在config.js
文件中设置。
VuePress 网站必要的配置文件是 .vuepress/config.js
,它应该导出一个 JavaScript 对象:
module.exports = { title: 'VuePress', description: 'VuePress', }
对于上述的配置,运行yarn docs:dev
,你应该能看到一个页面,它包含一个页头,里面包含一个标题和一个搜索框。
能够经过 themeConfig.nav
增长一些导航栏连接:
// .vuepress/config.js module.exports = { themeConfig: { nav: [ {text: '指南',link:'/guide/install/install'} ] } }
当你提供了一个 items
数组而不是一个单一的 link
时,它将显示为一个 下拉列表
:
module.exports = { themeConfig: { nav: [ { text: 'Languages', items: [ { text: 'Chinese', link: '/language/chinese/' }, { text: 'Japanese', link: '/language/japanese/' } ] } ] } }
想要使侧边栏(Sidebar)生效,须要配置 themeConfig.sidebar
// .vuepress/config.js module.exports = { themeConfig: { sidebar: [ { title: '开发指南', collapsable: false, //是否展开 }, ['./guide/install/install','安装'], ['./guide/started/started','快速上手'], { title: '组件', collapsable: false }, ['./guide/icon/icon','icon'], ] } }
能够省略 .md
拓展名,同时以 /
结尾的路径将会被视为 */README.md
若是想要显示地指定连接的文字,使用一个格式为 [link, text]
的数组。
具体配置能够根据官网配置:默认主题配置
这是浏览器显示效果:
如今页面基本也搭建完成,能够在页面之间进行切换。下一步是如何在markdown
中使用vue组件,也就是在页面中展现本身的项目。
在.vuepress
中建立components
文件夹。
全部在 .vuepress/components
中找到的 *.vue
文件将会自动地被注册为全局的异步组件。
若是须要引入静态文件,能够在.vuepress
下新建public
文件夹,里面能够放静态文件。
由于本文的案例是展现Icon图标,全部引入了svg.js
,svg.js
能够在http://www.iconfont.cn/中获取,本文使用symbol引用
具体方法请访问官网。放在public
文件夹中,能够在components
文件夹中的组件引入。
这是docs文件夹目录结构
. └─ .vuepress └─ components ├─ demo-1.vue └─ Icon └─ vi-icon.vue
能够直接使用这些组件在任意的 Markdown 文件中(组件名是经过文件名取到的):
<demo-1/> <Icon-vi-icon/> //文件名和组件名之间用`-`链接
完成这一步之后就能够在页面中看到本身的组件在页面中展现了,可是在运行下面命令进行打包的时候会报错:
报错缘由参考官网文档:浏览器的 API 访问限制
yarn docs:build 或者:npm run docs:build
解决这个问题只须要在使用Vue组件的markdown
文件中使用<ClientOnly></ClientOnly>
将组件包裹起来。如:
<ClientOnly> <Icon-vi-icon/> </ClientOnly>
注意:在markdown文件中若是须要给组件名缩进,不要用tab
键,会被当作markdown
语法解析。
浏览器效果图
到这一步,基本上能够在页面中展现本身的组件。下一篇将继续写如何经过Vue组件实现跟:Element类似的效果。