成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

尤大在 Vue的生態(tài)進展中提到的 style動態(tài)變量注入是啥?

開發(fā) 前端
在 Vue RFC 中有一個關(guān)于樣式的提案 SFC style CSS variable injection,這個 RFC 為Vue開發(fā)者提供了一種使用組件的響應(yīng)性數(shù)據(jù)作為CSS變量的方法。

[[403995]]

本文已經(jīng)過授權(quán)翻譯。

在 Vue RFC 中有一個關(guān)于樣式的提案 SFC style CSS variable injection,這個 RFC 為Vue開發(fā)者提供了一種使用組件的響應(yīng)性數(shù)據(jù)作為CSS變量的方法。

在Vue 3中,只需一個簡單的語法,我們就可以在運行時更新樣式。

在本文中,我們將了解如何使用這些SFC樣式,它是如何工作的,然后了解一些來自RFC的高級知識。

本文主要內(nèi)容:

1.如何使用SFC樣式?2. Vue中的響應(yīng)式樣式 3. Vue SFC 樣式變量如何工作 4. 需要知道的一些知識 1.CSS變量在子組件中不可用 2.使用前檢查瀏覽器支持情況 5 .總結(jié)

Single File Component : 單文件組件,簡稱 SFC

如何使用SFC樣式?

要使用這個特性,只需要兩個步驟:

  1. 在組件的script中聲明一個響應(yīng)式變量。
  2. 在 css 中使用 v-bind 來使用這個變量。

來個粟子:

  1. <template> 
  2. <div> 
  3.   <div class="text">hello</div> 
  4. </div> 
  5. </template> 
  6.  
  7. <script> 
  8. export default { 
  9.     data() { 
  10.         return { 
  11.             color: 'red'
  12.         } 
  13.     } 
  14. </script> 
  15.  
  16. <style> 
  17. .text { 
  18.     color: v-bind(color); 
  19. </style> 

很簡單。

如果查看瀏覽器中的組件,可以看到元素從數(shù)據(jù)中正確地獲得了其顏色的值

這也適用于更復(fù)雜的數(shù)據(jù)結(jié)構(gòu),假設(shè)我們有一個名為fontStyles的對象,該對象中有一個weight的屬性。

我們?nèi)匀皇褂胿-bind訪問它,但因為我們傳遞是一個對象,所以需要使用 JS 表達式來訪問這個內(nèi)部屬性,且需要將表達式括放在引號中。

  1. <template> 
  2. <div> 
  3.   <div class="text">hello</div> 
  4. </div> 
  5. </template> 
  6.  
  7. <script> 
  8. export default { 
  9.     data() { 
  10.         return { 
  11.             color: 'red'
  12.             font: { 
  13.                 weight: '800' 
  14.             } 
  15.         } 
  16.     } 
  17. </script> 
  18.  
  19. <style> 
  20. .text { 
  21.     color: v-bind(color); 
  22.     /* wrapped in quotes */ 
  23.     font-weight: v-bind('font.weight'); 
  24. </style> 

Vue中的響應(yīng)式樣式

無論我們是使用 JS 表達式還是僅僅使用根級數(shù)據(jù)綁定,我們都可以利用Vue的內(nèi)置響應(yīng)式在運行時更新樣式。

假設(shè)我們希望能夠使用一個按鈕來更改文本的顏色,那么可以這樣做。

  1. <div> 
  2.   <div class="text">hello</div> 
  3.   <button @click="color = 'blue'"> Make Blue </button> 
  4. </div> 

我們所要做的就是改變對應(yīng)的變量值,CSS樣式就會自己更新。這就是這個特性如此強大的原因,它為我們提供了一種干凈的方式來修改頁面在運行時的外觀。

Vue SFC 樣式變量如何工作

了解了使用方式之后,我們來看下 Vue 是怎么做到的。如果我們檢查元素,我們可以更好地了解Vue如何運作它的魔力。

在我們的樣式節(jié)中引用的任何變量都被作為內(nèi)聯(lián)樣式添加到組件的根元素中。

像普通的CSS那樣寫,我們聲明CSS變量-015c408c-color,并將其設(shè)置為red,將變量--015c408c-font_weight,設(shè)置為800。

  1. element.style { /* root element */ 
  2.     --015c408c-color: red; 
  3.     --015c408c-font_weight: 800; 
  4.  
  5. .text { 
  6.     color: var(--015c408c-color); 
  7.     font-weight: var(--015c408c-font_weight); 

然后就是將 v-bind 轉(zhuǎn)換成使用 CSS 變量方式。

然后,每當(dāng)響應(yīng)性數(shù)據(jù)發(fā)生變化時

  • 我們的內(nèi)聯(lián)樣式改變了,這意味著...
  • 我們的CSS變量改變了,這意味著...
  • 最終樣式更改為響應(yīng)式的新值

這就是如何在運行時更新樣式就像上面的 color 做的那樣。

CSS變量在子組件中不可用

為了避免繼承問題,定義的CSS變量對它的任何子組件都不可用。

例如,如果我們向現(xiàn)有組件添加一個子組件。

  1. <template> 
  2. <div> 
  3.   <div class="text">hello</div> 
  4.   <button @click="color = 'blue'"> Make Blue </button> 
  5.   <child-component /> 
  6.   </div> 
  7. </template> 
  8.  
  9. <script> 
  10. import ChildComponent from './ChildComponent.vue' 
  11. export default { 
  12.     components: { 
  13.         ChildComponent 
  14.     }, 
  15.     data() { 
  16.         return { 
  17.             color: 'red'
  18.             font: { 
  19.                 weight: '800' 
  20.             } 
  21.         } 
  22.     } 
  23. </script> 
  24.  
  25. <style> 
  26. .text { 
  27.   color: v-bind(color); 
  28.     /* expressions (wrap in quotes) */ 
  29.     font-weight: v-bind('font.weight'); 
  30. </style> 

假設(shè)子組件是這樣構(gòu)建的。

  1. <template> 
  2.     <div class="child-text"> Child Component </div> 
  3. </template> 
  4.  
  5. <style> 
  6.     .child-text { 
  7.         color: v-bind(color); 
  8.     } 
  9. </style> 

這不會改變顏色,因為我們的子組件不知道任何CSS變量。

使用前檢查瀏覽器支持情況

如果你想要項目使用該特性,需要先檢查一下瀏覽器對 CSS 變量的支持情況

總結(jié)

這是一個非常有趣的特性,類似于我們上次講的 script setup 語法,它最終將走出實驗階段,合并到Vue 3中。

將Vue用于CSS變量和SFC樣式變量是向Vue組件添加響應(yīng)式樣式的直觀方式。

很棒,期待!

作者:Fernando Doglio 譯者:前端小智 來源:medium

 

原文:https://learue.co/2020/01/a-vue-event-hanling-cheatsheet-the-essentials/

本文轉(zhuǎn)載自微信公眾號「大遷世界」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系大遷世界公眾號。

 

責(zé)任編輯:武曉燕 來源: 大遷世界
相關(guān)推薦

2023-06-27 07:31:59

微服務(wù)容錯庫重試

2020-03-07 09:47:48

AVL樹算法場景

2025-05-06 13:44:17

Vue前端人工智能

2020-08-12 11:05:32

Vue 源碼應(yīng)用

2012-04-29 10:35:06

2011-06-02 14:25:45

靜態(tài)變量

2021-05-24 08:04:03

script setuVue Vue 3

2023-11-22 10:12:43

Sortablejs拖拽庫

2022-07-06 10:02:12

Vue3.2ExposeAPI

2023-07-14 12:21:29

流程@Autowired方法

2018-07-30 11:27:12

云服務(wù)

2024-03-06 07:28:23

Vue前端開發(fā)Vapor 模式

2025-05-06 03:30:00

AIVueVite

2022-09-08 16:31:17

前端Web

2023-12-29 08:27:36

C語言靜態(tài)變量開發(fā)

2017-02-06 13:31:19

Android樣式繼承關(guān)系

2021-10-29 09:32:33

springboot 靜態(tài)變量項目

2010-11-26 15:38:32

MySQL注入

2011-07-11 16:13:01

Java靜態(tài)變量實例變量

2024-07-08 08:43:19

點贊
收藏

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

主站蜘蛛池模板: 亚洲色图网址 | 51ⅴ精品国产91久久久久久 | 成人午夜激情 | 涩涩视频在线观看免费 | 韩日精品在线观看 | 国产精品久久久久久中文字 | 国产日韩欧美电影 | 国产一区二区 | 日韩精品在线播放 | 久久国产成人 | 欧美色性 | 国产精品成人国产乱一区 | 99色视频| 日韩综合一区 | 午夜久久久久久久久久一区二区 | 亚洲伦理自拍 | 九九久久精品 | 一区二区三区四区av | 亚州国产 | 99精品99 | 亚洲在线一区二区 | 久久精品欧美电影 | 久久五月婷 | 亚洲精品一区二区三区中文字幕 | 成人欧美一区二区三区在线观看 | 国产欧美精品一区二区 | 国产精品国产三级国产播12软件 | 91精品国产91久久久久久最新 | 欧美一级在线免费观看 | 亚洲一区二区中文字幕在线观看 | 在线欧美小视频 | 欧美日韩亚洲国产综合 | 久久精品电影 | 亚洲成人免费观看 | 亚洲精品自在在线观看 | 欧美性a视频 | 亚洲国产一区二区三区, | 在线欧美一区 | 欧美日韩亚洲系列 | 在线播放中文字幕 | 精品国产鲁一鲁一区二区张丽 |