Vue--》深入学习Tailwind CSS掌握优雅而高效的前端样式开发

Tailwind CSS是一个非常强大且灵活的CSS框架,适用于开发者希望高度定制化界面样式的项目。今天博主就 Tailwind CSS 做一个简单介绍以及案例讲解,争取读者阅读文章后入门。

仅靠一篇文章博主也不可能将Tailwind CSS所有内容讲解的面面俱到,在阅读之前博主先将相关的官方文档链接打出来,详细了解Tailwind CSS的话还是推荐阅读 官方文档 ,如果英文水平较差的朋友推荐阅读 Tailwind CSS 中文网 。接下来开始正式的Tailwind CSS学习:

目录

上手Tailwind CSS

基于JIT模式的TailwindCSS

TailwindCSS生态和封装组件

自定义主题及样式


上手Tailwind CSS

Tailwind CSS是一种基于原子设计理念的现代CSS框架。它通过提供大量可复用的独立类来构建界面,而不是依赖于预定义的组件。与传统的CSS框架不同,Tailwind CSS不提供封装好的样式组件,而是专注于提供低级的原子类,使开发者能够自由组合和定制样式。

接下来我们借助官网的介绍使用vite框架创建vue项目来使用Tailwind CSS:

以下是使用创建Vue项目的相关命令,关于vite创建项目的介绍可参考我之前的文章:地址 ,注意如果使用下面命令创建最新版本的vite需要node版本在18.0以上,如果版本过低是创建不了的,如果想进行node多版本管理,可以参考我之前的文章:地址 。

使用vite创建完vue工程之后,接下来我们就需要为该项目安装Tailwind CSS依赖:

npm install -D tailwindcss postcss autoprefixer

回到package.json文件中我们可以看到我们已经安装完成了最新的包:

然后我们执行如下命令,使用 tailwindcss 初始化一个项目,并生成默认的配置文件。-p是一个可选参数,表示使用 PostCSS 进行构建和处理样式。如果存在 PostCSS 的配置文件,则会将 tailwindcss 集成到该文件中,以便使用 PostCSS 处理样式。不存在则创建:

npx tailwindcss init -p

接下来我们需要在生成的tailwind.config.js文件中配置如下的初始内容:

/** @type {import('tailwindcss').Config} */
export default {content: ['./index.html', './src/**/*.{vue,js,ts,jsx,tsx}'],theme: {extend: {},},plugins: [],
}

接下来我们需要在src文件下创建一个输入指令的css文件,这里命名为tailwind.css,在该文件夹下配置如下内容:

@tailwind base;
@tailwind components;
@tailwind utilities;

一开始使用会出现如下状况:Unknown at rule @tailwindcss(unknownAtRules):

可以在项目根目录下的 .vscode 目录中创建 settings.json 文件并添加以下代码:

{"css.lint.unknownAtRules": "ignore"
}

然后启动 Tailwind CLI 构建进程  运行 CLI 工具以扫描模板文件中的类并构建 CSS。 这个命令通常用于在开发过程中实时地将 tailwindcss 的样式应用到项目中,并自动更新生成的 CSS 文件。

npx tailwindcss -i ./src/input.css -o ./src/output.css --watch

接下来需要在src/main.ts 中引入 tailwindcss 编译的输出文件./src/output.css ,这里我将输入文件命名为tailwind.css,输出文件命名为style.css:

import { createApp } from 'vue'
import './tailwind.css'
import './style.css'
import App from './App.vue'createApp(App).mount('#app')

通常来说,在使用 Tailwind CSS 进行开发时,最终需要将 Tailwind CSS 的样式生成具体的 CSS 文件,然后将该 CSS 文件引入到项目中进行部署上线。这样可以确保在生产环境中使用已经处理好的 CSS 样式,避免依赖于实时编译和处理。这里我们通过如下操作,设置同时启动 vite 项目和 tailwindcss 监听的命令:

  "scripts": {"serve": "concurrently \"npm run dev\" \"npm run tail\"","dev": "vite","tail": "tailwindcss -i ./src/tailwind.css -o ./src/style.css --watch","build": "vite build","preview": "vite preview"},

关于 concurrently 是一个 Node.js 包,它允许你在一个命令行中同时运行多个命令,如果没有下载的朋友,这里推荐进行全局安装一下:

npm install -g concurrently

接下面我们在App.vue文件中进行如下的代码测试,这里推荐一下代码的提示插件,在vscode搜索即可:

这里提示一下这个插件可能存在的问题,目前博主安装这个插件遇到的情况是只有在书写类名后空格一下才能出现提示,不空格或者重新书写是没有任何提示的,这是由于VS代码处理字符串上下文的方式,在.vscode/settings.json中添加以下内容应该可以解决这个问题,简单提一嘴:

"editor.quickSuggestions": {"strings": true
}
<template><div><div class="h-screen bg-red-300 flex justify-center items-center">HelloWorld</div></div>
</template>

最终终端执行 npm run serve 得到的画面如下,说明我们操作成功:

基于JIT模式的TailwindCSS

在 Tailwind CSS 中,Just-in-Time (JIT) 编译模式的配置选项。是 Tailwind CSS v2.1.0 版本引入的一项新功能。

使用 JIT 编译模式可以显著提高 Tailwind CSS 的开发体验和编译速度。传统的编译模式需要扫描整个 Tailwind CSS 的源代码,并为每个可能用到的类生成对应的 CSS 样式规则,这样会导致编译时间较长。以下是没有开启JIT模式下的输出文件style.css的代码文件

而 JIT 编译模式是一种按需编译的方式,它只会根据你实际使用的类动态生成相关的样式规则,从而减少了编译时间和生成的 CSS 文件大小。这意味着你可以更快地编译和重载页面,并且无需担心生成大量未使用的 CSS。

要启用 JIT 编译模式,你需要在 Tailwind CSS 配置文件(通常是 tailwind.config.js)中的 mode 选项中设置为 'jit':

module.exports = {mode: 'jit',// 其他配置项...
}

然后我们将原本的设置的输入文件tailwind.css中的第一项代码注释掉:

/* @tailwind base; */
@tailwind components;
@tailwind utilities;

接下来点击输出文件style.css,就可以看到我们的css代码就是说明tailwind原子css生成的代码:

回到页面可以看到我们的代码样式也没有出现变化,大大提高了运行效率:

TailwindCSS生态和封装组件

TailwindCSS 本身并不是一个封装好的 UI 组件库,它更像是一个工具集,提供了大量的实用类来帮助你快速构建自定义的 UI。但结合 Tailwind UI 和其他开源组件库,你可以在项目中快速构建出美观且高效的用户界面。可以参考:地址 ,这里提供了TailwindCSS常用的组件库合集,总会找到适合你的那一款:

这里博主推荐一款好用的吧:地址 ,当然你可以找一下自己喜欢的组件库,都可以。这里就拿这个举例了:

我们拿一下这个 Banner 进行举例:

将代码复制到我们的vue文件当中:

回到我们的页面可以看到样式已经出现到我们的页面当中了:

在 Tailwind CSS 中,可以使用 @apply 指令来提取类并将其应用到自定义的 CSS 规则中。这允许你重复使用和抽象一组类,并将其应用于自定义的样式。接下来我们将上面的UI组件库的某行代码抽离出来制成下面的banner属性:

@tailwind base;
@tailwind components;
@tailwind utilities;@layer components {.banner {@apply relative flex flex-wrap bg-indigo-500 px-4 py-3 sm:flex-nowrap sm:items-center sm:justify-center sm:gap-3 sm:pr-8 md:px-8;}
}

接下来回到App组件中,我们使用我们创建好的banner属性:

回到页面当中,可以看到我们的页面仍然还是有效果的:

关于TailwindCSS官方提供的组件库是收费的这件事,博主这里就不再介绍该组件库的使用了,因为很贵,大部分人还是用不起的,翻阅上面博主提供的组件库集合的github地址,找找其他的组件库使用也可以,类似下面这种也是不错的:

地址:点击跳转

地址:点击跳转

地址:点击跳转

组件库仅是利于大家提高编程效率的途径而已,找到自己需要的资源进行编程即可。

自定义主题及样式

TailwindCSS提供给我们方便自定义主题及样式的方法,让我们定制网站更有代表性,当我们我们想使用某一个颜色的时候,通过tailwind.config.js设置的自定义主题颜色以及其他相关属性,让我们的定制更具有统一性:

/** @type {import('tailwindcss').Config} */
module.exports = {theme: {screens: {sm: '480px',md: '768px',lg: '976px',xl: '1440px',},colors: {'blue': '#1fb6ff','pink': '#ff49db','orange': '#ff7849','green': '#13ce66','gray-dark': '#273444','gray': '#8492a6','gray-light': '#d3dce6',},fontFamily: {sans: ['Graphik', 'sans-serif'],serif: ['Merriweather', 'serif'],},extend: {spacing: {'128': '32rem','144': '36rem',},borderRadius: {'4xl': '2rem',}}}
}

theme 对象包含 screens、colors 和 spacing 的键,以及每个可自定义的 核心插件 的键。有关主题选项的完整列表,请参阅 主题配置参考 或 默认主题。 

screens 键允许你自定义项目中的响应断点。

colors 键允许你为项目自定义全局调色板。

spacing 键允许你为项目自定义全局间距和大小比例。

theme 部分的其余部分用于配置哪些值可用于每个单独的核心插件。

如果你想保留主题选项的默认值,但还想添加新值,请在配置文件中的 theme.extend 键下添加扩展。该键下的值将与现有的 theme 值合并,并自动成为可供你使用的新类。

/** @type {import('tailwindcss').Config} */
module.exports = {theme: {extend: {fontFamily: {display: 'Oswald, ui-serif', // Adds a new `font-display` class}}}
}

将其添加到你的主题后,你可以像任何其他 font-{family} 工具一样使用它:

<h1 class="font-display">This uses the Oswald font
</h1>

要覆盖默认主题中的选项,请直接在 tailwind.config.js 的 theme 部分下添加你的覆盖,这将完全替换 Tailwind 对该键的默认配置,因此在下面的示例中,不会生成任何默认的透明度工具。

/** @type {import('tailwindcss').Config} */
module.exports = {theme: {// Replaces all of the default `opacity` valuesopacity: {'0': '0','20': '0.2','40': '0.4','60': '0.6','80': '0.8','100': '1',}}
}

写在最后

        通过本文我们了解了 Tailwind CSS 的一些基本概念和特点,以及它为开发人员提供的许多优势。Tailwind CSS 提供了一种全新的方式来构建用户界面,通过直接操作实用类来快速构建自定义样式,极大地提高了开发效率和灵活性。与传统的 CSS 框架相比,Tailwind CSS 不仅更加模块化和可扩展,而且具有出色的响应式设计和可访问性支持。学习和掌握 Tailwind CSS 不仅可以帮助我们更快地开发出现代化的用户界面,还能够提高我们对 CSS 的理解和应用能力。

        作为一个备受欢迎且不断发展的工具,学习和了解 Tailwind CSS 的重要性在不断增强。无论是前端开发人员还是设计师,掌握 Tailwind CSS 都将成为我们职业发展中的重要优势。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/681908.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

66万个 全国行政区划代码表

66万个全国各级行政区划代码表 提供的数据一览 简介 一共有66万个全国各级行政区划&#xff0c;一共有5个级别的行政单位级别 表格头部数据 表格尾部数据 全国行政单位各省份数量统计 数据下载地址 数据整理不易 百度云盘 链接: https://pan.baidu.com/s/1o1C2piYj2wu…

软件实例分享,宠物店兽医电子处方开单系统软件教程

软件实例分享&#xff0c;宠物店兽医电子处方开单系统软件教程 一、软件教程问答 以下教程以 佳易王宠物店兽医电子处方软件V16.0为例说明 软件文件下载可以点击最下方官网卡片——软件下载——试用版软件下载 问&#xff1a;宠物医院电子处方单子使用的纸张大小是多少&…

树莓派编程基础与硬件控制

1.编程语言 Python 是一种泛用型的编程语言&#xff0c;可以用于大量场景的程序开发中。根据基于谷歌搜 索指数的 PYPL&#xff08;程序语言流行指数&#xff09;统计&#xff0c;Python 是 2019 年 2 月全球范围内最为流行 的编程语言 相比传统的 C、Java 等编程语言&#x…

compile error ESP32cam.h no such file or directory

解决方法 可以参考这篇文章&#xff1a; But first, you will need to download the esp32cam.h library. For this go to Github and download the esp32cam Zip. GitHub - yoursunny/esp32cam: OV2640 camera on ESP32-CAM, Arduino library 具体就是下面的这篇重要的文章 …

URL编码算法:解决特殊字符在URL中的烦恼

引言&#xff1a; URL编码算法是一种将URL中的特殊字符转换为特定格式的编码方式。它在网络传输中起到了保护数据安全与完整性的重要作用。本文将深入探讨URL编码算法的优点与缺点&#xff0c;并介绍它在Web开发、网络安全等方面的应用。 URL编码解码 | 一个覆盖广泛主题工具…

抽象工厂模式-Abstract Factory Pattern

原文地址:https://jaune162.blog/design-pattern/abstract-factory-pattern/ 引言 首先我们由一个实际问题来引出抽象工厂模式。 考虑这样一个场景,系统中需要向OSS上传文件,以及通过OSS下载文件。而在系统中有不同的业务在使用这两个功能。如下图: 伪代码如下 public in…

怎么使用ChatGPT提高工作效率?

怎么使用ChatGPT提高工作效率&#xff0c;这是一个有趣的话题。 相信不同的人有不同的观点&#xff0c;大家的知识背景和从事的工作都不完全相同&#xff0c;所以最终ChatGPT能起到的作用也不一样。 在编程过程中&#xff0c;如果我们要找一个库&#xff0c;我们最先做的肯定…

算法讲解之字符串

前言&#xff1a; 本文主要讲解算法中和字符串结合的题目&#xff0c;跟字符串结合的算法题种类丰富&#xff0c;主要是跟别的算法结合&#xff0c;下面介绍几道比较经典的题目~ 第一道&#xff1a;14. 最长公共前缀 题目描述&#xff1a; 编写一个函数来查找字符串数组中的…

987. 二叉树的垂序遍历 - 力扣(LeetCode)

题目描述 给你二叉树的根结点 root &#xff0c;请你设计算法计算二叉树的 垂序遍历 序列。 对位于 (row, col) 的每个结点而言&#xff0c;其左右子结点分别位于 (row 1, col - 1) 和 (row 1, col 1) 。树的根结点位于 (0, 0) 。 二叉树的 垂序遍历 从最左边的列开始直到…

生活篇——华为手机去除负一屏

华为手机去除如下图的恶心负一屏 打开华为的应用市场app 进入&#xff1a;我的-设置-国家/地区&#xff08;改为俄罗斯&#xff09;-进入智慧助手检查更新并更新智慧助手。 然后重复开始的操作&#xff0c;将地区改回中国&#xff0c;这样就没有负一屏了。

初中生用什么台灯最好?精选高口碑的学生护眼台灯

其实现在的孩子从上初中开始&#xff0c;他们的学习压力就已经很大了&#xff0c;繁重的功课让他们经常用眼过度&#xff0c;导致早早就戴上小眼镜。所以要想孩子拥有一个良好的视力健康&#xff0c;不仅要从日常的坐姿、用眼习惯开始纠正、培养&#xff0c;夜晚学习时的那一盏…

状态监测防火墙详细工作流程

状态监测防火墙是一种用于监测和分析网络通信状态的安全设备。其工作流程通常包括以下几个步骤&#xff1a; 1. 采集数据&#xff1a;防火墙会采集来自网络流量的数据&#xff0c;包括 IP 地址、端口号、协议类型等信息&#xff0c;并将其存储在数据库中。 2. 分析数据&#xf…

CPython:表达式的求值顺序(evaluation order)

相关阅读 Pythonhttps://blog.csdn.net/weixin_45791458/category_12403403.html?spm1001.2014.3001.5482 C中表达式的求值 C语言针对表达式的计算&#xff0c;设置了操作符的优先级和结合性这两个特性&#xff0c;优先级用于解析不同优先级的符号&#xff0c;结合性用于解析…

2024年,要特别注意这两个方位

家居风水对每个家庭都非常重要&#xff0c;可在无形中影响到人们的事业、财富以及健康运势。俗话说&#xff1a;“风水轮流转”&#xff0c;2024年为甲辰龙年&#xff0c;斗转星移、九宫飞星将改变宫位&#xff0c;新一年的磁场即将启动&#xff0c;方位的吉凶也会重新变动&…

oracle单机打DBBP补丁

书接上回 ORA-600 adg无法查询故障-CSDN博客 https://blog.csdn.net/q195136130/article/details/135445378?spm1001.2014.3001.5502 单机安装DBBP 解压缩补丁包 unzip p34204559_121020_Linux-x86-64.zip 关闭数据库 su - oraclesqlplus / as sysdbashut immediate 检查…

Mac上软件闪退(意外退出)的解决方法

mac苹果电脑上运行软件会意外退出&#xff0c;怎么办&#xff0c;可以试试下面的方法&#xff0c;亲测可行&#xff01; 第一种方法&#xff1a; 1、打开访达&#xff0c;进入应用程序目录&#xff0c;找到闪退的软件图标&#xff0c;在软件图标上右键选择“显示简介”&#…

OpenCV 人脸检测(易上手版)

在丰富多彩的计算机视觉世界中&#xff0c;人脸检测是最有趣和最广泛应用的领域之一。无论是在安全系统、用户界面控制&#xff0c;还是在社交媒体中应用过滤器&#xff0c;准确有效地检测人脸的能力都是至关重要的。今天&#xff0c;很高兴与大家分享如何在 Python 中使用 Ope…

【网络攻防实验】【北京航空航天大学】【实验三、口令破解(Password Cracking)实验】

实验三、口令破解(Password Cracking)实验 一、 L0phtCrack破解实验 1、 注册L0phtCrack: 2、 设置口令: (1) 创建3个新账户: 帐户创建过程(以test-1为例): 帐户创建结果: (2) 使用L0phtCrack破解口令:(使用管理员账号运行程序) 口令破解结果: 正确破解口令…

探讨深度学习

深度学习 深度学习概述进展崛起框架 主页传送门&#xff1a;&#x1f4c0; 传送 深度学习 概述 深度学习是机器学习领域的一个分支&#xff0c;它是一种基于人工神经网络的学习方法&#xff0c;旨在让 计算机模仿人类大脑的神经结构和学习方式&#xff0c;从大量数据中学习并…