日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網營銷解決方案
系統(tǒng)學習Vue中使用CSS的各種方式

Vue 中使用 CSS 非常靈活,可通過 class 和 style 給元素動態(tài)綁定 CSS,今天內容詳細介紹使用規(guī)則:

成都創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網站制作、做網站、企業(yè)官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯(lián)網時代的鄯善網站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!

在未使用 Vue 框架時,可以通過 class 和 style 來給 HTML 元素添加 css,如果想動態(tài)修改 css 可直接操作 DOM 元素的屬性。在前端小課 第6天:使用CSS的三種方式 中我們講了 css 的引入方式。

如果想動態(tài)修改 css 樣式,多多少少有一些不便,vue 解決了這個問題。

一、class

在 Vue 模板中可以直接添加 class 屬性,而且支持多種方式,比如對象、數(shù)組、JS表達式,這些說白了就是為了能夠更靈活修改 class。

如果 css 在代碼中不會涉及到修改,直接使用靜態(tài)的 class 就行:

 
 
 
  1. 《前端小課》
 

如果,某些 css 會根據不同的業(yè)務發(fā)生變化,這時就需要進行動態(tài)綁定 class,vue 中提供了多種方法:

1. 模板中寫對象

這種語法規(guī)則類似在 js 中定義一個對象,如果 isDark 為真,將給 h1 元素綁定 dark-text,否則綁定 light-text。

 
 
 
  1. {{title}} 

需要定義 css dark-text 和 light-text,只有這樣才能夠把樣式渲染到 HTML 元素上。

 
 
 
  1. .dark-text { 
  2.     color: #fff; 
  3. .light-text { 
  4.     color: #000; 

在 js 中定義屬性 isDark,這樣可以修改 isDark 的值,樣式便可以動態(tài)修改。

 
 
 
  1. data() { 
  2.     return { 
  3.         isDark: false, 
  4.         title: '前端小課' 
  5.     } 

2. js 中寫對象

你可以把動態(tài) class 的邏輯直接寫到 JS 代碼中,這種寫法可以減輕模板中定義太多的業(yè)務邏輯。

 
 
 
  1. {{title}} 
 
 
 
  1. .dark-text { 
  2.     color: #fff; 
  3. .light-text { 
  4.     color: #000; 
 
 
 
  1. data() { 
  2.     return { 
  3.         colorMode: { 
  4.             dark: false 
  5.         }, 
  6.         textMode: { 
  7.             'dark-text': false, 
  8.             'light-text': true 
  9.         }, 
  10.         title: '前端小課' 
  11.     }, 
  12.     methods: { 
  13.         changeMode() { 
  14.             const isDark = this.colorMode.dark; 
  15.             this.textMode['dark-text'] = isDark; 
  16.             this.textMode['light-text'] = !isDark; 
  17.         } 
  18.     } 
  19. }, 

3. 使用數(shù)組

以上兩種方式可以通過數(shù)組設置多個 class,語法和 js 中的數(shù)組定義一致。

 
 
 
  1. 本文來自公眾號素燕
 
 
 
 
  1. .content { 
  2.     color: #000; 
  3.     font-size: 17px; 
  4.     margin: 10px; 
  5. .stress { 
  6.     color: red; 
 
 
 
  1. data() { 
  2.     return { 
  3.         isStress: true, 
  4.         contentObj: { 
  5.             content: true 
  6.         } 
  7.     } 

4. 使用三元表達式

 
 
 
  1. 本文來自公眾號素燕
 
 
 
 
  1. .stress { 
  2.     color: red; 
 
 
 
  1. data() { 
  2.     return { 
  3.         isStress: true 
  4.     } 

二、style

vue 也可以通過 style 給 HTML 元素設置屬性。用法和 class 用法一致。如果希望通過 style 的方式給 HTML 元素設置 css,可以通過 :style 來動態(tài)給 HTML 動態(tài)綁定 css。

1. 在模板中使用對象

模板中定的對象,給元素設置了字體顏色和字體大小,通過屬性值 activeColor 和 fontSize 動態(tài)修改元素的字體顏色和大小。

 
 
 
 
 
 
 
  1. data() { 
  2.   return { 
  3.     activeColor: 'blue', 
  4.     fontSize: 20 
  5.   } 

2. 在 js 中定義對象

把設置樣式的對象直接定義到 js 中而非模板中。

 
 
 
 
 
 
 
  1. data() { 
  2.   return { 
  3.     contentStyle: { 
  4.         color: 'blue', 
  5.         fontSize: 20 
  6.     } 
  7.   } 

3. 使用數(shù)組

把設置樣式的對象直接定義到 js 中而非模板中。

 
 
 
 
 
 
 
  1. data() { 
  2.   return { 
  3.       fs: 20, 
  4.       contentStyle: { 
  5.         color: 'blue' 
  6.       } 
  7.   } 

今天的內容比較簡單,基本都是語法規(guī)則,大家加油!


當前名稱:系統(tǒng)學習Vue中使用CSS的各種方式
文章URL:http://www.dlmjj.cn/article/dhiogpj.html