自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

關(guān)于 Vue 樣式的七個(gè)你(可能)不知道的技巧

開(kāi)發(fā) 前端
作用域樣式不會(huì)消除對(duì)類(lèi)的需求。由于 CSS 選擇器的工作方式,當(dāng)使用作用域時(shí),p { color: red } 的速度會(huì)慢很多倍。如果使用類(lèi)來(lái)代替,性能方面的影響可以忽略不計(jì)。

單文件組件由三個(gè)不同的實(shí)體組成:模板、腳本和樣式。所有這些都很重要,但后者往往被忽視,盡管它可能會(huì)變得復(fù)雜,并經(jīng)常導(dǎo)致挫折和錯(cuò)誤。更好地理解可以改進(jìn)代碼審查并減少調(diào)試時(shí)間。

這里有 7 個(gè)小貼士可以幫助你:

  • 1.樣式作用域和插槽內(nèi)容
  • 2.作用域選擇器性能
  • 3.全局樣式
  • 4.樣式中的 Javascript 變量
  • 5.CSS 模塊
  • 6.CSS 與 SCSS 中的變量
  • 7.SCSS include 與 extend

1.樣式作用域和插槽內(nèi)容

將樣式的作用域限定為只影響當(dāng)前組件,是防止組件耦合和意外副作用的有效策略。

它是通過(guò)添加 scoped 屬性來(lái)轉(zhuǎn)換以下內(nèi)容來(lái)實(shí)現(xiàn)的:

<template>
  <div class="title">Hello world!</div>
</template>

<style scoped>
  .title {
    font-size: 24px;
  }
</style>

to

<template>
  <div class="title" data-v-7ba5bd90>Hello world!</div>
</template>

<style scoped>
  .title[data-v-7ba5bd90] {
    font-size: 24px;
  }
</style>

如果想讓樣式影響子組件,可以使用 deep 選擇器。

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

其編譯為:

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

使用插槽選擇器對(duì)插槽內(nèi)的內(nèi)容也是如此。

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

2.作用域選擇器性能

作用域樣式不會(huì)消除對(duì)類(lèi)的需求。由于 CSS 選擇器的工作方式,當(dāng)使用作用域時(shí),p { color: red } 的速度會(huì)慢很多倍。如果使用類(lèi)來(lái)代替,性能方面的影響可以忽略不計(jì)。

<!-- 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.全局樣式

影響整個(gè)應(yīng)用程序的樣式可能不是一個(gè)好主意。如果您還是想這么做,可以將作用域樣式與非作用域樣式混合使用,或者使用 :global 偽選擇器

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

4.樣式中的 Javascript 變量

自 Vue 3.2 版起,可以在樣式標(biāo)簽內(nèi)使用 v-bind。這可以帶來(lái)一些有趣的用例,比如只需幾行代碼就能實(shí)現(xiàn)顏色選擇器。

<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>

一個(gè)更高級(jí)的用例是使可重用應(yīng)用程序圖標(biāo)組件的圖標(biāo)大小動(dòng)態(tài)化。

<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 模塊

只需在樣式標(biāo)簽中添加 module 屬性,即可立即支持 CSS 模塊。這些類(lèi)會(huì)通過(guò) $style 變量自動(dòng)顯示在模板中。

<template>
  <p :class="$style.red">This should be red</p>
</template>

<style module>
  .red {
    color: red;
  }
</style>

6.CSS 與 SCSS 中的變量

SCSS 變量是我們編寫(xiě) CSS 方式的一次重大變革。在使用預(yù)處理器之前,使用變量是不可能的。此后,CSS 迎頭趕上,現(xiàn)在所有主流瀏覽器都支持 CSS 變量。CSS 變量提供了 SCSS 變量所能做到的一切,此外還提供了更簡(jiǎn)便的主題功能,因此在這場(chǎng)爭(zhēng)論中,CSS 變量明顯勝出。

7.SCSS include 與 extend

這兩個(gè) SCSS 助手經(jīng)常會(huì)引起混淆,因?yàn)樗鼈兌伎梢杂脕?lái)減少 SCSS 代碼的重復(fù)。CSS 輸出中存在一些細(xì)微的差別,您應(yīng)該注意。

@include 幫助程序用于包含在 mixin 塊中編寫(xiě)的代碼。

<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 將根據(jù)需要多次重復(fù)代碼

.error-text {
  color: red;
  font-size: 24px;
}

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

這里的 error mixin 只有一條規(guī)則,但在實(shí)際應(yīng)用中通常會(huì)有更復(fù)雜的 mixin。

另一方面,當(dāng)元素幾乎相同時(shí) @extend 更有用。

<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>

生成的代碼為:

.error-notification,
.error-text {
  color: red;
}

.error-text {
  font-size: 24px;
}

.error-notification {
  border: 1px solid red;
  padding: 8px;
}

這里的一般規(guī)則是選擇 extend,除非你想在 mixin 中使用一個(gè)參數(shù),在這種情況下,只有 include 才有效。

原文:https://fadamakis.com/7-quick-tips-about-vue-styles-you-might-didnt-know-5ec2fcecb384

責(zé)任編輯:武曉燕 來(lái)源: 獨(dú)立開(kāi)發(fā)者張張
相關(guān)推薦

2023-04-09 23:37:31

JavaScript開(kāi)發(fā)

2024-04-01 07:58:49

Next.js 14ReactWeb應(yīng)用

2015-08-13 09:03:14

調(diào)試技巧

2020-01-29 19:40:36

Python美好,一直在身邊Line

2021-01-05 11:22:58

Python字符串代碼

2019-11-20 10:25:06

sudoLinux

2024-03-04 00:00:00

Kubernetes技巧API

2020-12-14 07:51:16

JS 技巧虛值

2022-12-07 08:16:50

Vue 3技巧數(shù)組

2020-11-03 09:51:04

JavaScript開(kāi)發(fā) 技巧

2017-11-07 21:58:25

前端JavaScript調(diào)試技巧

2020-10-28 08:06:09

Vue3框架數(shù)據(jù)

2023-12-21 14:40:09

Python編程語(yǔ)言

2022-09-20 11:58:27

NpmNode.js

2014-04-10 13:15:54

PythonPython技巧

2022-12-12 13:19:11

Vue3開(kāi)發(fā)技巧

2012-11-23 10:57:44

Shell

2010-09-13 16:12:06

Mozilla實(shí)驗(yàn)室

2023-02-20 15:04:24

開(kāi)發(fā)API工具

2023-02-21 15:25:33

開(kāi)發(fā)工具API
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)