当前位置:首页 > 科技  > 软件

关于 Vue 样式的七个你(可能)不知道的技巧

来源: 责编: 时间:2023-11-06 17:19:38 353观看
导读单文件组件由三个不同的实体组成:模板、脚本和样式。所有这些都很重要,但后者往往被忽视,尽管它可能会变得复杂,并经常导致挫折和错误。更好地理解可以改进代码审查并减少调试时间。这里有 7 个小贴士可以帮助你:1.样式作

单文件组件由三个不同的实体组成:模板、脚本和样式。所有这些都很重要,但后者往往被忽视,尽管它可能会变得复杂,并经常导致挫折和错误。更好地理解可以改进代码审查并减少调试时间。mEC28资讯网——每日最新资讯28at.com

这里有 7 个小贴士可以帮助你:mEC28资讯网——每日最新资讯28at.com

  • 1.样式作用域和插槽内容
  • 2.作用域选择器性能
  • 3.全局样式
  • 4.样式中的 Javascript 变量
  • 5.CSS 模块
  • 6.CSS 与 SCSS 中的变量
  • 7.SCSS include 与 extend

1.样式作用域和插槽内容

将样式的作用域限定为只影响当前组件,是防止组件耦合和意外副作用的有效策略。mEC28资讯网——每日最新资讯28at.com

它是通过添加 scoped 属性来转换以下内容来实现的:mEC28资讯网——每日最新资讯28at.com

<template>  <div class="title">Hello world!</div></template><style scoped>  .title {    font-size: 24px;  }</style>

tomEC28资讯网——每日最新资讯28at.com

<template>  <div class="title" data-v-7ba5bd90>Hello world!</div></template><style scoped>  .title[data-v-7ba5bd90] {    font-size: 24px;  }</style>

如果想让样式影响子组件,可以使用 deep 选择器。mEC28资讯网——每日最新资讯28at.com

<style scoped>  .a :deep(.b) {    /* ... */  }</style>

其编译为:mEC28资讯网——每日最新资讯28at.com

.a[data-v-7ba5bd90] .b {  /* ... */}

使用插槽选择器对插槽内的内容也是如此。mEC28资讯网——每日最新资讯28at.com

<style scoped>  :slotted(div) {    color: red;  }</style>

2.作用域选择器性能

作用域样式不会消除对类的需求。由于 CSS 选择器的工作方式,当使用作用域时,p { color: red } 的速度会慢很多倍。如果使用类来代替,性能方面的影响可以忽略不计。mEC28资讯网——每日最新资讯28at.com

<!-- DO --><template>  <h1 class="title">Hello world!</h1></template><style scoped>  .title {    font-size: 24px;  }</style>
<!-- DONT --><template>  <h1>Hello world!</h1></template><style scoped>  h1 {    font-size: 24px;  }</style>

3.全局样式

影响整个应用程序的样式可能不是一个好主意。如果您还是想这么做,可以将作用域样式与非作用域样式混合使用,或者使用 :global 伪选择器mEC28资讯网——每日最新资讯28at.com

<style scoped>  :global(.red) {    color: red;  }</style>

4.样式中的 Javascript 变量

自 Vue 3.2 版起,可以在样式标签内使用 v-bind。这可以带来一些有趣的用例,比如只需几行代码就能实现颜色选择器。mEC28资讯网——每日最新资讯28at.com

<template>  <h1 class="text">Hello World!</h1>  <input type="color" v-model="color" /></template><script setup>  import { ref } from "vue";  const color = ref("");</script><style>  .text {    color: v-bind(color);  }</style>

一个更高级的用例是使可重用应用程序图标组件的图标大小动态化。mEC28资讯网——每日最新资讯28at.com

<template>  <p>    <input type="radio" v-model="size" :value="sizes.s" />S    <input type="radio" v-model="size" :value="sizes.m" />M    <input type="radio" v-model="size" :value="sizes.l" />L    <input      type="radio"      v-model="size"      :value="sizes.xl"    />XL  </p>  <div class="icon" /></template><script setup lang="ts">  import { ref } from "vue";  enum sizes {    s = 8,    m = 16,    l = 32,    xl = 64,  }  const size = ref(sizes.xl);</script><style>  .icon {    width: v-bind(size + "px");    height: v-bind(size + "px");    background: #cecece;  }</style>

5.CSS 模块

只需在样式标签中添加 module 属性,即可立即支持 CSS 模块。这些类会通过 $style 变量自动显示在模板中。mEC28资讯网——每日最新资讯28at.com

<template>  <p :class="$style.red">This should be red</p></template><style module>  .red {    color: red;  }</style>

6.CSS 与 SCSS 中的变量

SCSS 变量是我们编写 CSS 方式的一次重大变革。在使用预处理器之前,使用变量是不可能的。此后,CSS 迎头赶上,现在所有主流浏览器都支持 CSS 变量。CSS 变量提供了 SCSS 变量所能做到的一切,此外还提供了更简便的主题功能,因此在这场争论中,CSS 变量明显胜出。mEC28资讯网——每日最新资讯28at.com

7.SCSS include 与 extend

这两个 SCSS 助手经常会引起混淆,因为它们都可以用来减少 SCSS 代码的重复。CSS 输出中存在一些细微的差别,您应该注意。mEC28资讯网——每日最新资讯28at.com

@include 帮助程序用于包含在 mixin 块中编写的代码。mEC28资讯网——每日最新资讯28at.com

<template>  <p class="error-text">Hello World!</p>  <p class="error-notification">Hello World!</p></template><style lang="scss">  @mixin error {    color: red;  }  .error-text {    @include error;    font-size: 24px;  }  .error-notification {    @include error;    border: 1px solid red;    padding: 8px;  }</style>

生成的 CSS 将根据需要多次重复代码mEC28资讯网——每日最新资讯28at.com

.error-text {  color: red;  font-size: 24px;}.error-notification {  color: red;  border: 1px solid red;  padding: 8px;}

这里的 error mixin 只有一条规则,但在实际应用中通常会有更复杂的 mixin。mEC28资讯网——每日最新资讯28at.com

另一方面,当元素几乎相同时 @extend 更有用。mEC28资讯网——每日最新资讯28at.com

<template>  <p class="error-text">Hello World!</p>  <p class="error-notification">Hello World!</p></template><style lang="scss">  %error {    color: red;  }  .error-text {    @extend %error;    font-size: 24px;  }  .error-notification {    @extend %error;    border: 1px solid red;    padding: 8px;  }</style>

生成的代码为:mEC28资讯网——每日最新资讯28at.com

.error-notification,.error-text {  color: red;}.error-text {  font-size: 24px;}.error-notification {  border: 1px solid red;  padding: 8px;}

这里的一般规则是选择 extend,除非你想在 mixin 中使用一个参数,在这种情况下,只有 include 才有效。mEC28资讯网——每日最新资讯28at.com

原文:https://fadamakis.com/7-quick-tips-about-vue-styles-you-might-didnt-know-5ec2fcecb384mEC28资讯网——每日最新资讯28at.com

mEC28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-17270-0.html关于 Vue 样式的七个你(可能)不知道的技巧

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 使用C++实现数独求解器:解密数独的算法之美

下一篇: 答读者问:BeanFactoryPostProcessor 似乎失效了?

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 中兴AX5400Pro+上手体验:再升级 双2.5G网口+USB 3.0这次全都有

    2021年11月的时候,中兴先后发布了两款路由器产品,中兴AX5400和中兴AX5400 Pro,从产品命名上就不难看出这是隶属于同一系列的,但在外观设计上这两款产品可以说是完全没一点关系
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    在 Elasticsearch 中,function_score 可以让我们在查询的同时对搜索结果进行自定义评分。function_score 提供了一系列的参数和函数让我们可以根据需求灵活地进行设置。近期
  • 慕岩炮轰抖音,百合网今何在?

    来源:价值研究所 作者:Hernanderz&ldquo;难道就因为自己的一个产品牛逼了,从客服到总裁,都不愿意正视自己产品和运营上的问题,选择逃避了吗?&rdquo;这一番话,出自百合网联合创
  • 郭明錤称华为和江淮汽车合作开发问界MPV,定价100万左右、计划明年量产

    8 月 1 日消息,郭明錤今天在 Medium 平台发布博文,称华为正在和江淮汽车合作,开发售价在 100 万元的问界 MPV,预计在 2024 年第 2 季度量产,销量目标为
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
Top