data:image/s3,"s3://crabby-images/707ce/707ce7e824b7b7f06f1360e3a2f9e2d8a98d8255" alt="基于Astro博客的搭建"
基于Astro博客的搭建
Thu Aug 15 2024
环境
Node.js:一个开源的、跨平台的 JavaScript 运行时环境
pnpm:速度快、节省磁盘空间的软件包管理器
Node.js可以直接点开上面的连接下载最新版本并安装
pnpm在命令行使用下面的命令安装
BASH
1
npm install -g pnpm
可以在安装完成在命令行输入
BASH
1
pnpm -v
输出为版本即成功安装。
其他需要的
- 一个Github账号
- “魔法”(相信你既然能打开我的博客,魔法已经不是问题)
- VScode(推荐),其他代码编辑器也可以
主题选择
你可以在Themes | Astro上挑选自己喜欢的主题
在选择的主题中,可以点击”Live Demo”实时预览
主题拷贝
以下面的Theme为例
data:image/s3,"s3://crabby-images/23542/23542b9cad95f6e6dd83b8263820326ef4a569b3" alt="image-20240815005733024"
点击”Get started”会跳转到Github仓库
data:image/s3,"s3://crabby-images/82768/82768bc55c1e999e7533785ad8f17277bea03aa4" alt="image-20240815005935754"
记住左上角标红部分是:仓库所有者/仓库名,也就是template(模板)名称
首先在本地磁盘上新建一个文件夹,比如叫做”My_Blog”
在空白文件夹页,右键,选择用VSCode编辑(或者直接VSCode中手动打开该文件夹)
在VSCode中Crtl+J打开终端
此时地址应该是定位在当前文件夹,比如
BASH
1
PS D:\My_Blog>
输入命令
PYTHON
1
npm create astro@latest -- --template EveSunMaple/Frosti
稍等片刻会出现
data:image/s3,"s3://crabby-images/f32e7/f32e7837938e744e9a0f13171fd96ef291e91724" alt="image-20240815012032660"
意思是在何处create project
Crtl+删除键后键入./
data:image/s3,"s3://crabby-images/f626b/f626bd8349c16f46c776aebde5472c32ffecb468" alt="image-20240815011550647"
此处注意./后必须加一个英文空格,否则会有报错Invalid non-printable character present!
此后一路回车
data:image/s3,"s3://crabby-images/6a21d/6a21d70315a42799d3312f8c1b080c24ec5d0849" alt="image-20240815013022194"
如果此处卡在第三步,魔法挂“全局代理”
安装完成后会有提示如下
data:image/s3,"s3://crabby-images/eca90/eca9071cc2ba3d2f9a71b14c7448ddf347a293bc" alt="image-20240815013114529"
此时文件夹目录如下
PLAINTEXT
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
My_Blog
├─ .git
│ ├─ config
│ ├─ description
│ ├─ HEAD
│ ├─ hooks
│ │ ├─ applypatch-msg.sample
│ │ ├─ commit-msg.sample
│ │ ├─ fsmonitor-watchman.sample
│ │ ├─ post-update.sample
│ │ ├─ pre-applypatch.sample
│ │ ├─ pre-commit.sample
│ │ ├─ pre-merge-commit.sample
│ │ ├─ pre-push.sample
│ │ ├─ pre-rebase.sample
│ │ ├─ pre-receive.sample
│ │ ├─ prepare-commit-msg.sample
│ │ ├─ push-to-checkout.sample
│ │ ├─ sendemail-validate.sample
│ │ └─ update.sample
│ ├─ index
│ ├─ info
│ │ └─ exclude
│ ├─ objects
│ │ ├─ 03
│ │ │ └─ 12e514bfe7052ce6637004f107e58dc0751327
│ │ ├─ 06
│ │ │ └─ da51f4c0a61e89186e002cf1b4ec5a93b56a13
│ │ ├─ ...
│ │ ├─ info
│ │ └─ pack
│ └─ refs
│ ├─ heads
│ └─ tags
├─ .github
│ └─ ISSUE_TEMPLATE
│ ├─ 🚀-enhancement-request.md
│ └─ 🛠️-bug-report.md
├─ .gitignore
├─ .vscode
│ ├─ extensions.json
│ └─ launch.json
├─ 400-lighthouse.png
├─ astro.config.mjs
├─ CODE_OF_CONDUCT.md
├─ CONTRIBUTING.md
├─ Frosti_1.png
├─ LICENSE
├─ package-lock.json
├─ package.json
├─ pnpm-lock.yaml
├─ public
│ ├─ favicon.ico
│ ├─ favicon.svg
│ ├─ fonts
│ │ └─ CascadiaCode.woff2
│ ├─ home.webp
│ ├─ index.webp
│ ├─ l.png
│ ├─ profile.webp
│ ├─ r.png
│ └─ view.png
├─ README.md
├─ README.zh-CN.md
├─ SECURITY.md
├─ src
│ ├─ components
│ │ ├─ BaseCard.astro
│ │ ├─ BaseHead.astro
│ │ ├─ blog
│ │ │ ├─ collapse.astro
│ │ │ ├─ diff.astro
│ │ │ ├─ error.astro
│ │ │ ├─ info.astro
│ │ │ ├─ kbd.astro
│ │ │ ├─ success.astro
│ │ │ └─ warning.astro
│ │ ├─ CategoryCard.astro
│ │ ├─ CommentTwikoo.astro
│ │ ├─ CommentWaline.astro
│ │ ├─ Content.astro
│ │ ├─ EnvelopeCard.astro
│ │ ├─ Footer.astro
│ │ ├─ Header.astro
│ │ ├─ HeaderMenu.astro
│ │ ├─ License.astro
│ │ ├─ page
│ │ │ ├─ LinkCard.astro
│ │ │ └─ TimeLine.astro
│ │ ├─ ProfileCard.astro
│ │ ├─ ProfileCardFooter.astro
│ │ ├─ ProfileCardMenu.astro
│ │ ├─ ProjectCard.astro
│ │ ├─ ProjectJS.astro
│ │ ├─ TagCard.astro
│ │ └─ ThemeIcon.astro
│ ├─ consts.ts
│ ├─ content
│ │ ├─ blog
│ │ │ ├─ frosti-mdx.mdx
│ │ │ ├─ How-to-customize-code-box.mdx
│ │ │ ├─ markdown-style-guide.md
│ │ │ ├─ using-mdx copy.mdx
│ │ │ ├─ using-mdx.mdx
│ │ │ └─ Welcome_to_use_CSDN-markdown_Editor_new.mdx
│ │ └─ config.ts
│ ├─ env.d.ts
│ ├─ icons
│ │ ├─ menu
│ │ │ ├─ about.svg
│ │ │ ├─ blog.svg
│ │ │ ├─ categories.svg
│ │ │ ├─ contact.svg
│ │ │ ├─ cube.svg
│ │ │ ├─ friend.svg
│ │ │ ├─ heart.svg
│ │ │ ├─ home.svg
│ │ │ ├─ post.svg
│ │ │ └─ project.svg
│ │ └─ social
│ │ ├─ bilibili.svg
│ │ ├─ github.svg
│ │ ├─ rss.svg
│ │ ├─ support.svg
│ │ └─ zhihu.svg
│ ├─ layouts
│ │ └─ BaseLayout.astro
│ ├─ pages
│ │ ├─ about.mdx
│ │ ├─ blog
│ │ │ ├─ categories
│ │ │ │ └─ [category]
│ │ │ │ └─ [...page].astro
│ │ │ ├─ tag
│ │ │ │ └─ [tag]
│ │ │ │ └─ [...page].astro
│ │ │ ├─ [...page].astro
│ │ │ └─ [...slug].astro
│ │ ├─ friend.mdx
│ │ ├─ index.mdx
│ │ ├─ project.mdx
│ │ └─ rss.xml.js
│ ├─ styles
│ │ ├─ global.scss
│ │ ├─ transitions.scss
│ │ └─ waline.scss
│ └─ types.ts
├─ tailwind.config.js
└─ tsconfig.json
在命令行键入下面的命令安装必要的内容
BASH
1
npm installl
托管到Github
data:image/s3,"s3://crabby-images/195da/195dacbe9946b377b829647cc7c4bc3a15912248" alt="image-20240815014500548"
data:image/s3,"s3://crabby-images/9c6e8/9c6e87615414d4d180ac7b7d5cdfe44dc3457aa9" alt="image-20240815014532189"
data:image/s3,"s3://crabby-images/4e9aa/4e9aa49f556acadcdbcfa2bb5506489b99da3631" alt="image-20240815014640289"
在本地文件夹的命令行依次键入以上命令即可托管到Github
后续仓库的更新此处不再讲解
部署到Vercel
在网站Vercel用Github账号注册
data:image/s3,"s3://crabby-images/bd1ce/bd1cec5c855fca96b69d1754d4be223c78258ea6" alt="image-20240815015004578"
data:image/s3,"s3://crabby-images/c77f7/c77f7776f4a69c218bd770b14551e7ae59197e6d" alt="image-20240815015029332"
data:image/s3,"s3://crabby-images/d346c/d346c0c6d07e509dffc2a58312386a95b822af5e" alt="image-20240815015058414"
点击Deploy,稍等片刻看到烟花即为部署成功!