十分钟用vitepress搭建项目文档


theme: juejin

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第5天,点击查看活动详情

前言

前些天,用尽平生所学,写了一篇技术文章,Vue3项目框架搭建封装,一次学习,终身受益【万字长文,满满干货】,可惜掘金给的流量不多,点赞的人不多,评论的人几乎没有,收藏的人却不少,我想可能是万字长文看起来太吃力,于是花了3天时间用vitepress搭建了一个项目文档,方便大家查阅。

文档地址:yinzhuo19970516.github.io/

欢迎大家点赞,评论,收藏就算了,收藏了也不看。

现在,我准备花10min介绍一下,介绍一下这个vuepress的小兄弟,vitepress

vitepress是什么

vitepress 是一款基于vite vue3的静态站点生成器

有什么问题看文档吧,推荐看英文文档,中文文档不全

遇到问题建议去github gitee 搜索,目前这类的博客比较少

英文文档

中文文档

vitepress怎么用

新建文件夹,文件夹下新建目录

js . ├─ docs │ └─ index.md

初始化

JS npm init npm i vitepress package.json添加script JSON "scripts": { "dev": "vitepress dev docs --open", "build": "vitepress build docs", "serve": "vitepress serve docs" }, ### 运行 js npm run dev 最基础的搭建就成功了 ### 加配置文件 在docs目录下创建一个 .vuepress目录,如下结构 . ├─ docs │ ├─ .vitepress │ │ └─ config.js │ └─ index.md └─ package.json

配置项目介绍

以我配置的为例 ```js export default { title: 'vue-template',// 网站标题 description: 'vue-cli/二次封装/vue3/axios/多入口打包', //网站描述 ignoreDeadLinks: true,// 最好加上,构建时会忽略md中的外链 markdown: { theme: 'material-palenight',//md主题 lineNumbers: true//md 加行号 }, lastUpdated: true,//显示最近更新时间 appearance: true,//可以选择深浅主题

// 主题配置 themeConfig: { socialLinks: [//右上角图标和链接,icon 可用svg 配置 { icon: 'github', link: 'https://github.com/Yinzhuo19970516/vue-template' }, { icon: 'slack', link: 'https://juejin.cn/user/1011206428301774' } ], lastUpdatedText: '更新时间', siteTitle: 'vue-template', nav: [//右侧导航 { text: '首页', link: '/' }, { text: '项目简介', link: '/page/index' }, { text: '更新日志', link: 'https://github.com/Yinzhuo19970516/vue-template/blob/main/CHANGELOG.md' } ], // 侧边导航 sidebar: [ { text: '项目简介', items: [ { text: '为什么要写这个项目', link: '/page/why' }, { text: '多入口打包', link: '/page/pages' }, { text: '自动化生成项目基本模版', link: '/page/init' }, { text: 'Pinia',link:'/page/pinia'}, { text: '数据持久化',link:'/page/piniaPlugin'}, { text: 'axios二次封装',link:'/page/axios'}, { text: '路由跳转动画',link:'/page/router'}, { text: 'less sass的优化处理',link:'/page/less'}, { text: 'viewport适配方案',link:'/page/viewport'}, { text: '环境变量',link:'/page/env'}, { text: '兼容性处理方案',link:'/page/babel'}, { text: '总结', link: '/page/all' }, ] } ], outlineTitle: '目录' } } ```

首页布局

首页就是进入我们博客会加载docs/index.md,所以我们需要对其进行一个美化,我们VitePress默认主题提供了一个主页布局 参考我的吧,具体的意思很明显了,首页还挺好看的。

```

layout: home title: vue-template description: vue-cli/二次封装/vue3/axios/多入口打包

hero: name: vue-template🎉 text: tagline: 基于vue3,vue-cli4二次封装的移动端框架 actions: - theme: brand text: 开始 link: /page/index - theme: alt text: 访问github

link: https://github.com/Yinzhuo19970516/vue-template

```

运行

明暗交错,非常不错 js npm run dev

image.png

image.png

打包

js npm run build 默认在.vitepress/dist 目录下

部署到GitHub Pages

先在github新建一个仓库,、仓库命名为username.github.io的形式,username是你github的用户名。然后点击设置。

我的在这里:https://github.com/Yinzhuo19970516/Yinzhuo19970516.github.io 可直接抄作业,setting->pages->Brach->save

把dist 文件下的文件push 到建立的仓库里即可。

自动化部署

vitepress官方怕我们太累,提供给了一个脚本deploy.sh直接可以抄作业

我每次就是本地直接 zsh deploy.sh

过一会,https://yinzhuo19970516.github.io/ 这个网站就会有最近的更新

```

!/usr/bin/env sh

确保脚本抛出遇到的错误

set -e

生成静态文件

npm run build

进入生成的文件夹

cd docs/.vitepress/dist

git init git add -A git commit -m 'deploy'

git push -f git@github.com:Yinzhuo19970516/Yinzhuo19970516.github.io.git master cd - ```

总结

还不错的一个文档框架,后续会在上面主要更新我的项目文档,有兴趣可以一起讨论,一起学习。

仓库地址

文档地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是搭建一个 Maven 的 Shiro 十分钟快速上手完整测试项目的步骤: 1. 创建 Maven 项目 首先,我们需要创建一个 Maven 项目。可以使用 Eclipse、IntelliJ IDEA 等 IDE,也可以使用 Maven 命令行创建。这里我使用 IntelliJ IDEA 创建 Maven 项目。 在 IntelliJ IDEA 中,选择 File -> New -> Project,在弹出的窗口中选择 Maven,然后点击 Next。 在 Create Maven Project 窗口中,填 GroupId、ArtifactId 和 Version,然后点击 Next。 接着,在 New Project 窗口中,填项目名称和项目路径,然后点击 Finish。 2. 添加 Shiro 依赖 在 pom.xml 文件中添加 Shiro 依赖: ```xml <dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-core</artifactId> <version>1.7.1</version> </dependency> ``` 3. 配置 Shiro 在 src/main/resources 目录下创建 shiro.ini 文件,配置 Shiro: ```ini [users] # 用户名 = 密码, 角色1, 角色2, ... admin = admin123, admin guest = guest123, guest [roles] # 角色名 = 权限1, 权限2, ... admin = * guest = user:read [urls] # URL = 过滤器1, 过滤器2, ... / = anon /login = anon /logout = logout /admin/** = authc, roles[admin] /user/** = authc, roles[guest] ``` 以上配置文件定义了两个用户 admin 和 guest,admin 拥有 admin 角色,guest 拥有 guest 角色。admin 角色拥有所有权限,guest 角色只有 user:read 权限。配置了一些 URL 的访问规则,例如 /admin/** 表示必须登录并且拥有 admin 角色才能访问。 4. 编测试代码 在 src/test 目录下创建一个测试类,编测试代码: ```java import org.apache.shiro.SecurityUtils; import org.apache.shiro.authc.UsernamePasswordToken; import org.apache.shiro.config.IniSecurityManagerFactory; import org.apache.shiro.mgt.SecurityManager; import org.apache.shiro.subject.Subject; import org.apache.shiro.util.Factory; import org.junit.Test; public class ShiroTest { @Test public void testLogin() { // 读取 shiro.ini 配置文件,并创建 SecurityManager Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini"); SecurityManager securityManager = factory.getInstance(); SecurityUtils.setSecurityManager(securityManager); // 获取当前用户 Subject currentUser = SecurityUtils.getSubject(); // 登录 UsernamePasswordToken token = new UsernamePasswordToken("admin", "admin123"); currentUser.login(token); // 判断是否登录成功 assert currentUser.isAuthenticated(); // 判断是否拥有 admin 角色 assert currentUser.hasRole("admin"); // 判断是否拥有 user:read 权限 assert currentUser.isPermitted("user:read"); // 退出登录 currentUser.logout(); // 判断是否退出成功 assert !currentUser.isAuthenticated(); } } ``` 以上测试代码首先读取 shiro.ini 配置文件,并创建 SecurityManager。然后获取当前用户,使用 admin 用户登录,判断登录是否成功,判断是否拥有 admin 角色和 user:read 权限,退出登录,判断是否退出成功。 5. 运行测试 在 IntelliJ IDEA 中,可以直接运行测试类,或者使用 Maven 命令运行测试: ``` mvn test ``` 测试结果应该全部通过。 至此,一个 Maven 的 Shiro 十分钟快速上手完整测试项目搭建好了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值