Vue中的scoped及穿透方法

来源:https://www.cnblogs.com/karthuslorin/archive/2018/05/15/9038854.html
-Advertisement-
Play Games

何為scoped? 在vue文件中的style標簽上,有一個特殊的屬性:scoped。當一個style標簽擁有scoped屬性時,它的CSS樣式就只能作用於當前的組件,也就是說,該樣式只能適用於當前組件元素。通過該屬性,可以使得組件之間的樣式不互相污染。如果一個項目中的所有style標簽全部加上了s ...


何為scoped?

在vue文件中的style標簽上,有一個特殊的屬性:scoped。當一個style標簽擁有scoped屬性時,它的CSS樣式就只能作用於當前的組件,也就是說,該樣式只能適用於當前組件元素。通過該屬性,可以使得組件之間的樣式不互相污染。如果一個項目中的所有style標簽全部加上了scoped,相當於實現了樣式的模塊化。

scoped的實現原理

vue中的scoped屬性的效果主要通過PostCSS轉譯實現,如下是轉譯前的vue代碼:

<style scoped>
.example {
  color: red;
}
</style>

<template>
  <div class="example">hi</div>
</template>

轉譯後:

<style>
.example[data-v-5558831a] {
  color: red;
}
</style>

<template>
  <div class="example" data-v-5558831a>hi</div>
</template>

即:PostCSS給一個組件中的所有dom添加了一個獨一無二的動態屬性,然後,給CSS選擇器額外添加一個對應的屬性選擇器來選擇該組件中dom,這種做法使得樣式只作用於含有該屬性的dom——組件內部dom。

為什麼需要穿透scoped?

scoped看起來很美,但是,在很多項目中,會出現這麼一種情況,即:引用了第三方組件,需要在組件中局部修改第三方組件的樣式,而又不想去除scoped屬性造成組件之間的樣式污染。此時只能通過特殊的方式,穿透scoped。

<style scoped>
    外層 >>> 第三方組件 {
        樣式
    }
</style>

通過 >>> 可以使得在使用scoped屬性的情況下,穿透scoped,修改其他組件的值。

曲線救國的方法

其實,還擁有一種曲線救國的方法,即在定義一個含有scoped屬性的style標簽之外,再定義一個不含有scoped屬性的style標簽,即在一個vue組件中定義一個全局的style標簽,一個含有作用域的style標簽:

<style>
/* global styles */
</style>

<style scoped>
/* local styles */
</style>

此時,你只需要將修改第三方樣式的css寫在第一個style中即可。

個人推薦的方法

以上兩種方法,穿透方法實際上違反了scoped屬性的意義,曲線救國的方法又使得代碼太過於難看。

個人推薦第三種方法,即:由於scoped看起來很美好,但是含有很多的坑,所以,不推薦不使用scoped屬性,而通過在外層dom上添加唯一的class來區分不同組件。這種方法既實現了類似於scoped的效果,又方便修改各種第三方組件的樣式,代碼看起來也相對舒適。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、在控制面板,卸載MySQL的所有組件 控制面板——》所有控制面板項——》程式和功能,卸載所有和MySQL有關的程式 二、找到你的MysQL安裝路徑,看還有沒有和MySQL有關的文件夾,全刪 如果安裝在C盤,檢查一下C:\Program Files (x86)和C:\Program Files 這 ...
  • 記得以前客戶在使用軟體時,有偶發出現死鎖問題,因為發生的時間不確定,不好做問題的重現,當時解決問題有點棘手了。 現總結下查看死鎖的常用二種方式: 第一種是圖形化監聽: sqlserver -->工具--> sql server profiler 登錄後在跟蹤屬性中選擇如下圖: 監聽到的死鎖圖形如下圖 ...
  • 一,增強現實 增強現實(AR)是一種實時地計算攝影機影像的位置及角度並加上相應圖像的技術,這種技術的目標是在屏幕上把虛擬世界套在現實世界併進行互動。這種技術估計由1990年提出。隨著隨身電子產品運算能力的提升,預期增強現實的用途將會越來越廣。 二,視頻捕獲 捕獲視頻的方法有兩個,一個方法是錄製視頻保 ...
  • 問題描述: 業務上初始化過程要求顯示閃屏界面,某個版本更新後,發現部分場景下,初始化完成後閃屏界面不消失。 問題原因: 初始化是在子線程進行,閃屏屬於UI界面,需要UI線程展示。初始化過程和閃屏顯示在不同線程,UI線程忙碌的時候,會出現業務的初始化已經執行完成,閃屏界面才真正顯示。 解決措施: 方案 ...
  • MainActivity: NetworkInterface: MultiAsynctaskNetwork: 核心類MultiAsynctask: ...
  • public class Main { /** * 程式入口 */ public void start() { // 第一種,先進先出的隊列 // YolandaLinkedQueue queue = new YolandaLinkedQueue(3); // queue.start(); //..... ...
  • iOS 常用三方 1、ZWMSegmentController 分頁控制器 https://github.com/weiming4219/ZWMSegmentController ...
  • 聲明:此為本人原創,只想實現功能,界面樣式方面沒多考慮,很粗糙能看懂就行……2018-5-14 動態生成table,我利用jsp內嵌java代碼從後臺獲取對象集合,輸出的時候有2中方法 1.直接利用java代碼for(b1 b:bs)輸出 2.利用JSTL標簽庫的c:foreach輸出 不同之處在於 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...