Skip to content

Commit

Permalink
deploy
Browse files Browse the repository at this point in the history
  • Loading branch information
hooray committed Aug 26, 2024
1 parent f43fd93 commit 39a9d12
Show file tree
Hide file tree
Showing 5 changed files with 432 additions and 383 deletions.
2 changes: 1 addition & 1 deletion .vitepress/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ _hmt.push(['_requirePlugin', 'UrlChangeTracker', {
{ text: '路由', link: '/guide/router' },
{ text: '与服务端交互', link: '/guide/axios' },
{ text: '全局状态管理', link: '/guide/store' },
{ text: '全局资源', link: '/guide/global-resources' },
{ text: '资源', link: '/guide/resources' },
{ text: '图标', link: '/guide/svg-icon' },
{ text: '构建与预览', link: '/guide/build' },
],
Expand Down
35 changes: 0 additions & 35 deletions guide/global-resources.md

This file was deleted.

101 changes: 101 additions & 0 deletions guide/resources.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# 资源

## 图片

### 全局公共

全局公共图片存放在 `/src/assets/images/` 目录下,可自行新建文件夹分类管理。

### 局部私有

局部私有图片建议采用就近原则,你可以在需要的模块文件夹下建立一个 `images` 文件夹,专门用于存放局部私有组件。

## 样式

### 全局公共

全局公共样式存放在 `/src/assets/styles/` 目录下,可自行新建文件,并在 `/src/main.ts` 中引入即可。

此目录下还有一个特殊目录,即 `/src/assets/styles/resources/` ,这是全局 SCSS 资源目录,你可以在该目录下编写变量、函数、混合等支持 SCSS 特性的代码。

### 局部私有

基于单文件组件规范,局部私有样式建议直接在 `.vue` 文件中编写,框架集成了 UnoCSS / PostCSS / SCSS 方案,可选择自己适合的方案。更多单文件组件 CSS 功能请参考[这里](https://cn.vuejs.org/api/sfc-css-features)

#### UnoCSS

```vue
<template>
<div class="flex flex-1 flex-col select-none text-center all:transition-400">
<div class="ma">
<div class="animate-bounce-alt animate-duration-1s animate-count-infinite text-5xl fw100">
UnoCSS
</div>
</div>
</div>
</template>
```

#### PostCSS

框架内置了 [postcss-nested](https://github.com/postcss/postcss-nested) 插件,可实现接近于 SCSS 的写法和特性。

```vue
<style scoped>
.phone {
&_title {
width: 500px;
@media (max-width: 500px) {
width: auto;
}
body.is_dark & {
color: white;
}
}
img {
display: block;
}
}
</style>
```

#### SCSS

```vue
<style lang="scss" scoped>
$width: 500px;
.phone {
&_title {
width: $width;
@media (max-width: $width) {
width: auto;
}
body.is_dark & {
color: white;
}
}
img {
display: block;
}
}
</style>
```

## 组件

### 全局公共

::: tip 说明
全局公共组件在使用时,无需手动引入,框架会在你使用时自动引入,该特性由 [unplugin-vue-components](https://github.com/unplugin/unplugin-vue-components) 提供支持。
:::

全局公共组件存放在 `/src/components/` 目录下,每个组件按文件夹进行区分。

每个组件的文件夹内至少保留一个文件名为 `index.vue` 的组件入口(可参考 `SvgIcon` 组件),文件夹名称即为组件名。

推荐使用 `pnpm new` 指令进行组件生成,详细可查看《[代码文件自动生成](plop)》。

### 局部私有

局部私有组件建议采用就近原则,你可以在需要的模块文件夹下建立一个 `components` 文件夹,专门用于存放局部私有组件。
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,9 @@
"vitepress-plugin-comment-with-giscus": "^1.1.15"
},
"devDependencies": {
"@antfu/eslint-config": "^2.26.0",
"eslint": "^9.9.0",
"vitepress": "1.3.3",
"@antfu/eslint-config": "^2.27.1",
"eslint": "^9.9.1",
"vitepress": "1.3.4",
"vue": "^3.4.38"
}
}
Loading

0 comments on commit 39a9d12

Please sign in to comment.