AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

關于 Vue 樣式的七個你(可能)不知道的技巧

來源: 責編: 時間:2023-11-06 17:19:38 271觀看
導讀單文件組件由三個不同的實體組成:模板、腳本和樣式。所有這些都很重要,但后者往往被忽視,盡管它可能會變得復雜,并經常導致挫折和錯誤。更好地理解可以改進代碼審查并減少調試時間。這里有 7 個小貼士可以幫助你:1.樣式作

單文件組件由三個不同的實體組成:模板、腳本和樣式。所有這些都很重要,但后者往往被忽視,盡管它可能會變得復雜,并經常導致挫折和錯誤。更好地理解可以改進代碼審查并減少調試時間。gUg28資訊網——每日最新資訊28at.com

這里有 7 個小貼士可以幫助你:gUg28資訊網——每日最新資訊28at.com

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

1.樣式作用域和插槽內容

將樣式的作用域限定為只影響當前組件,是防止組件耦合和意外副作用的有效策略。gUg28資訊網——每日最新資訊28at.com

它是通過添加 scoped 屬性來轉換以下內容來實現的:gUg28資訊網——每日最新資訊28at.com

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

togUg28資訊網——每日最新資訊28at.com

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

如果想讓樣式影響子組件,可以使用 deep 選擇器。gUg28資訊網——每日最新資訊28at.com

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

其編譯為:gUg28資訊網——每日最新資訊28at.com

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

使用插槽選擇器對插槽內的內容也是如此。gUg28資訊網——每日最新資訊28at.com

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

2.作用域選擇器性能

作用域樣式不會消除對類的需求。由于 CSS 選擇器的工作方式,當使用作用域時,p { color: red } 的速度會慢很多倍。如果使用類來代替,性能方面的影響可以忽略不計。gUg28資訊網——每日最新資訊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 偽選擇器gUg28資訊網——每日最新資訊28at.com

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

4.樣式中的 Javascript 變量

自 Vue 3.2 版起,可以在樣式標簽內使用 v-bind。這可以帶來一些有趣的用例,比如只需幾行代碼就能實現顏色選擇器。gUg28資訊網——每日最新資訊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>

一個更高級的用例是使可重用應用程序圖標組件的圖標大小動態化。gUg28資訊網——每日最新資訊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 變量自動顯示在模板中。gUg28資訊網——每日最新資訊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 變量明顯勝出。gUg28資訊網——每日最新資訊28at.com

7.SCSS include 與 extend

這兩個 SCSS 助手經常會引起混淆,因為它們都可以用來減少 SCSS 代碼的重復。CSS 輸出中存在一些細微的差別,您應該注意。gUg28資訊網——每日最新資訊28at.com

@include 幫助程序用于包含在 mixin 塊中編寫的代碼。gUg28資訊網——每日最新資訊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 將根據需要多次重復代碼gUg28資訊網——每日最新資訊28at.com

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

這里的 error mixin 只有一條規則,但在實際應用中通常會有更復雜的 mixin。gUg28資訊網——每日最新資訊28at.com

另一方面,當元素幾乎相同時 @extend 更有用。gUg28資訊網——每日最新資訊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>

生成的代碼為:gUg28資訊網——每日最新資訊28at.com

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

這里的一般規則是選擇 extend,除非你想在 mixin 中使用一個參數,在這種情況下,只有 include 才有效。gUg28資訊網——每日最新資訊28at.com

原文:https://fadamakis.com/7-quick-tips-about-vue-styles-you-might-didnt-know-5ec2fcecb384gUg28資訊網——每日最新資訊28at.com

gUg28資訊網——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-17270-0.html關于 Vue 樣式的七個你(可能)不知道的技巧

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 使用C++實現數獨求解器:解密數獨的算法之美

下一篇: 答讀者問:BeanFactoryPostProcessor 似乎失效了?

標簽:
  • 熱門焦點
  • 盧偉冰長文解析K60至尊版 對Redmi有著里程碑式的意義

    在今天的Redmi后性能時代戰略發布會結束之后,Redmi總經理盧偉冰又帶來了一篇長文,詳解了為什么 Redmi 要開啟后性能時代?為什么選擇和 MediaTek、Pixelworks 深度合作?以及后性
  • 影音體驗是真的強 簡單聊聊iQOO Pad

    大公司的好處就是產品線豐富,非常細分化的東西也能給你做出來,例如早先我們看到了新的vivo Pad2,之后我們又在iQOO Neo8 Pro的發布會上看到了iQOO的首款平板產品iQOO Pad。雖
  • Raft算法:保障分布式系統共識的穩健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可復制、可冗余、可容錯”)的首字母縮寫。Raft算法是一種用于在分布式系統
  • 2023年,我眼中的字節跳動

    此時此刻(2023年7月),字節跳動從未上市,也從未公布過任何官方的上市計劃;但是這并不妨礙它成為中國最受關注的互聯網公司之一。從2016-17年的抖音強勢崛起,到2018年的&ldquo;頭騰
  • “又被陳思誠騙了”

    作者|張思齊 出品|眾面(ID:ZhongMian_ZM)如今的國產懸疑電影,成了陳思誠的天下。最近大爆電影《消失的她》票房突破30億斷層奪魁暑期檔,陳思誠再度風頭無兩。你可以說陳思誠的
  • 當家的盒馬,加速謀生

    來源 | 價值星球Planet作者 | 歸去來自己&ldquo;當家&rdquo;的盒馬,開始加速謀生了。據盒馬官微消息,盒馬計劃今年開放生鮮供應鏈,將其生鮮商品送往食堂。目前,盒馬在上海已經與
  • 微博大門常打開,迎接海外畫師漂洋東渡

    作者:互聯網那些事&ldquo;起猛了,我能看得懂日語了&rdquo;。&ldquo;為什么日本人說話我能聽懂?&rdquo;&ldquo;中文不像中文,日語不像日語,但是我竟然看懂了&rdquo;&hellip;&hell
  • 華為Mate 60保護殼曝光:碩大后置相機模組 凸起程度有驚喜

    這段時間以來,關于華為新旗艦的爆料日漸密集。據此前多方爆料,今年華為將開始恢復一年雙旗艦戰略,除上半年推出的P60系列外,往年下半年的Mate系列也將
  • onebot M24巧系列一體機采用輕薄機身設計,現已在各平臺開售

    onebot M24 巧系列一體機目前已在線上線下各平臺同步開售。onebot M24 巧系列采用一體化輕薄機身設計,最薄處為 10.15mm,擁有寶石紅、午夜藍、石墨綠、雅致
Top