从 16 个方向逐步搭建基于 Vue3 的前端架构,python计算机毕业项目

5.1 安装与配置

安装:

npm i unplugin-vue-components -D

配置:

// vite.config.ts

import Components from ‘unplugin-vue-components/vite’

export default defineConfig({

plugins: [

Components({ /* options */ }),

],

})

这里的 options 可以配置一些选项,后面提到的组件库注册会使用到。

5.2 改变全局组件注册方式

我们通常将全局的组件封装在 @/src/components 中,然后通过 app.component() 注册全局组件。使用此插件后,无需手写注册,直接在模板中使用组件即可:

这里引入官方的示例:

自动编译为:

5.3 自动引入组件库

在使用组件库时,常规组件我们也会注册到全局,如果使用局部注册由于页面中会使用到多个组件,会非常麻烦,所以这个功能绝佳,例如我们使用 ant-design-vue 组件库。

直接在模板中使用即可,无需手动注册或局部引用:

按钮

当然,你还需要在 vite 中引入它的解析器:

import Components from ‘unplugin-vue-components/vite’

import { AntDesignVueResolver } from ‘unplugin-vue-components/resolvers’

export default defineConfig({

plugins: [

Components({

resolvers: [

AntDesignVueResolver(),

]

})

],

})

目前支持的解析器,根据你的喜好去选择:

  • Ant Design Vue[11]

  • Element Plus[12]

  • Element UI[13]

  • Headless UI[14]

  • IDux[15]

  • Naive UI[16]

  • Prime Vue[17]

  • Vant[18]

  • VEUI[19]

  • Varlet UI[20]

  • View UI[21]

  • Vuetify[22]

  • VueUse Components[23]

  • Quasar[24]

6.样式


项目中最好使用通用样式,可以创建 src/styles 目录存放,这里推荐一些分类:

styles

├── antd # 组件库样式覆盖,命名自取,这里以 ant design 为例

├── color.less # 颜色

├── index.less # 入口

├── global.less # 公共类

├── transition.less # 动画相关

└── variable.less # 变量

6.1 预设基础样式

相信用过 normalize[25] 的同学不在少数,它可以重置 css 样式,使各浏览器效果保持一致。后面的章节会提到 tailwind.css,它内置了预设样式重置的功能,与 normalize 还是有一定的区别,有兴趣的同学可以了解一下[26]。

6.2 CSS 预处理器

虽然 vite 原生支持 less/sass/scss/stylus,但是你必须手动安装他们的预处理器依赖,例如:

npm install -D less

如何选择预处理器?

推荐使用你是所使用的组件库的样式语言,因为 css 预处理器学会一种后,入手其他几乎没有学习成本。

6.3 开启 scoped

没有加 scoped 属性,会编译成全局样式,造成全局污染。

6.4 深度选择器

有时我们可能想明确地制定一个针对子组件的规则。

如果你希望 scoped 样式中的一个选择器能够作用得“更深”,例如影响子组件,你可以使用 >>> 操作符。有些像 Sass 之类的预处理器无法正确解析 >>>。这种情况下你可以使用 /deep/ 或 ::v-deep 操作符取而代之——两者都是 >>> 的别名,同样可以正常工作。

7.布局


页面整体布局是一个产品最外层的框架结构,往往会包含导航、页脚、侧边栏等。在页面之中,也有很多区块的布局结构。在真实项目中,页面布局通常统领整个应用的界面,有非常重要的作用,所以单独拆分出来也是非常有必要的。

在脚手架中,所有的通用布局组件都应该放在 src/layouts 中,这种封装比较简单,这里就不贴代码了,大家按照自己实际情况自行发挥,在此仅提供一下封装思路。

7.1 常规的布局

BasicLayout

基础页面布局,包含了头部导航,侧边栏等。

BlankLayout

空白的布局。

7.2 特殊的布局

RouteLayout

如果你的项目在路由切换中需要对某些二级页面进行缓存,那么推荐你创建一个 RouteLayout,通过路由 meta 中的配置,返回 router-view 或者使用 keep-alive 包裹的 router-view

UserLayout

用于用户登录注册等页面抽离出来。

PageLayout

基础布局,包含了面包屑等信息,内含 slot。

8.集成 Tailwind.css


Tailwind.css[27] 在我第一次看到它的时候,内心是比较反感的,但实际上手之后又觉得真香。从 vue2 项目中,我已经引入了 tailwind,整体的开发结果就是,基本很少再使用 <style> 标签去转本定义一些 class 和样式,毕竟起名字这种事,一个是涉及到规范,一个是涉及到英语。如果你选择 tailwind,CSS 预处理器的作用就会显得微乎其微,因为你无需再自定定义各种变量和 mixins。

总体来说,学习成本并不高,花上两个小时足够上手,记住不用死记硬背那些类名。

8.1 效率提升

很多人总是说样式要与 HTML 分离,现在为什么又要提倡 tailwind 这种与 HTML 紧密结合的工具?这是因为现在使用 vue 这类框架已经高度组件化,样式分离是为了方便复用和维护,但在组件化面前样式分离只能是降低开发效率。

下面

  • 11
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 作为后端语言,在构建前端架构时通常不是直接担当主角,但它可以通过各种方式配合其他技术来支持前端应用。以下是一些常见的 Python前端架构中的角色和搭配: 1. **Flask/Django** - Python 的轻量级框架 Flask 和全功能框架 Django 提供了 Web 应用的基础结构,这些框架通常用于搭建服务器端接口 (RESTful APIs),供前端(如 JavaScript、React、Vue 或 Angular)调用。 2. **FastAPI** - 近年来流行的 FastAPI 另外一种简洁高效的选择,它专注于高性能的 API 开发。 3. **微服务** - Python 可以作为微服务架构中的一部分,每个服务可能有自己的 Python 后端,并通过 RESTful API 连接。 4. **非阻塞 I/O** - Python 有一些库,如 Gevent 或 trio,帮助处理高并发场景,适合那些对实时性和性能敏感的应用。 5. **Docker** - Python 可以用于编写 Dockerfile,实现容器化部署,从而更好地管理前端项目的运行环境。 6. **数据处理与分析** - Python 在大数据处理和数据分析方面的强大能力,可以帮助前端提供丰富的数据源或支持实时的数据可视化。 7. **自动化工具** - 使用 Python 编写脚本,比如 Jenkins, GitLab CI/CD 或者 npm scripts,进行持续集成/交付(CI/CD)流程。 对于具体的前端架构来说,Python 通常会与 JavaScript 配合,因为 JavaScript 是前端开发的主要语言。它们可能会一起构建一个前后端分离(SPA)应用,或者利用诸如 GraphQL、Webpack 等技术协同工作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值