一起學Vue之樣式綁定

来源:https://www.cnblogs.com/hsiang/archive/2019/12/18/12064085.html
-Advertisement-
Play Games

在前端開發中,設置元素的 class 列表和內聯樣式是基本要求。本文主要講解Vue開發中,樣式列表和內聯樣式的綁定,僅供學習分享使用,如果有不足之處,還請指正。 ...


在前端開發中,設置元素的 class 列表和內聯樣式是基本要求。本文主要講解Vue開發中,樣式列表和內聯樣式的綁定,僅供學習分享使用,如果有不足之處,還請指正。

概述

Vue操作元素的 class 列表和內聯樣式是數據綁定的一個常見需求。因為它們都是屬性,所以我們可以用 v-bind 處理它們:只需要通過表達式計算出字元串結果即可。不過,字元串拼接麻煩且易錯。因此,在將 v-bind 用於 class 和 style 時,Vue.js 做了專門的增強。表達式結果的類型除了字元串之外,還可以是對象或數組。

綁定 HTML Class

可以傳給 v-bind:class 一個對象,以動態地切換 class:

1 <div v-bind:class="{red:isred,bold:isbold}">混合樣式1--綁定數據屬性</div>

上面的語法表示 red 這個 class 存在與否將取決於數據屬性 isred 的 是否為true。你可以在對象中傳入更多屬性來動態切換多個 class。此外,v-bind:class 指令也可以與普通的 class 屬性共存。

綁定的數據對象採用複合樣式的效果,不必內聯定義在模板里,如下所示:

1 <div v-bind:class="multi">混合樣式2---複合對象</div>

其中multi是一個複合數據對象,如下所示:

 1 <script type="text/javascript">
 2     var vm=new Vue({
 3         el:"#app",
 4         data:{
 5             bg:'yellow',
 6             isbold:true,
 7             isred:true,
 8             multi:{
 9                 red:true,
10                 bold:true,
11             }
12         }
13 
14     });
15 </script>

以上兩種,結果渲染是一樣的,如下所示:

1 <div class="red bold"></div>

綁定計算屬性

我們也可以在這裡綁定一個返回對象的計算屬性。這是一個常用且強大的模式:

1 <div v-bind:class="cmpstyle">混合樣式3---計算屬性</div>

其中cmpstyle是一個計算屬性,返回的對象,如下所示:

 1 <script type="text/javascript">
 2     var vm=new Vue({
 3         el:"#app",
 4         computed:{
 5             cmpstyle:function(){
 6                 return {
 7                     red:true,
 8                     bold:true,
 9                 }
10             }
11         }
12     });
13 </script>

CSS數組語法

我們可以把一個數組傳給 v-bind:class,以應用一個 class 列表:

1 <div v-bind:class="arrcss">混合樣式4---數組綁定樣式</div>

其中arrcss是一個數組樣式,如下所示:

1 <script type="text/javascript">
2     var vm=new Vue({
3         el:"#app",
4         data:{
5             arrcss:['red','bold'],
6         }
8     });
9 </script>

綁定內聯樣式

v-bind:style 的對象語法十分直觀——看著非常像 CSS,但其實是一個 JavaScript 對象。CSS 屬性名可以用駝峰式 (camelCase) 或短橫線分隔 (kebab-case,記得用引號括起來) 來命名:

1 <div v-bind:style="{color:bg2}">內聯樣式2--屬性</div>

綁定內聯樣式,直接綁定到一個樣式對象通常更好,這會讓模板更清晰:

1  <div v-bind:style="bg3">內聯樣式3--綁定對象</div>

其中,bg3是一個對象,如下所示:

 1 <script type="text/javascript">
 2     var vm=new Vue({
 3         el:"#app",
 4         data:{
 5             bg2:'green',
 6             bg3:{
 7                 color:'red',
 8                 fontSize:'30px'
 9             }
10         }
11     });
12 </script>

內聯樣式數組語法

v-bind:style 的數組語法可以將多個樣式對象應用到同一個元素上:

1 <div v-bind:style="[bg3,bg4]">內聯樣式4--綁定對象</div>

多重值

從 2.3.0 起你可以為 style 綁定中的屬性提供一個包含多個值的數組,常用於提供多個帶首碼的值,例如:

1 <div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

這樣寫只會渲染數組中最後一個被瀏覽器支持的值。在本例中,如果瀏覽器支持不帶瀏覽器首碼的 flexbox,那麼就只會渲染 display: flex。

本示例中源碼如下:

  1 <!DOCTYPE html>
  2 <html>
  3     <head>
  4         <meta charset="UTF-8">
  5         <title>一起學Vue之綁定樣式</title>
  6         <!-- 開發環境版本,包含了有幫助的命令行警告 -->
  7         <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  8         <style type="text/css">
  9             .red{
 10                 color:red;
 11             }
 12             .yellow{
 13                 color: goldenrod;
 14             }
 15             .green{
 16                 color: green;
 17             }
 18             .bold{
 19                 font:bolder;
 20                 font-style: oblique;
 21             }
 22         </style>
 23     </head>
 24     <body>
 25         <div id="app">
 26             <div v-bind:class="bg">
 27                 這是我的顏色
 28             </div>
 29             <!--
 30                 作者:[email protected]
 31                 時間:2019-11-20
 32                 描述:Html樣式:可以傳給 v-bind:class 一個對象,以動態地切換 class:
 33                 上面的語法表示 active 這個 class 存在與否將取決於數據屬性 isActive 的 是否為true。
 34             -->
 35             <div v-bind:class="{red:isred,bold:isbold}">混合樣式1--綁定數據屬性</div>
 36             <!--
 37                 作者:[email protected]
 38                 時間:2019-11-20
 39                 描述:綁定的數據對象採用複合樣式的效果,不必內聯定義在模板里
 40             -->
 41             <div v-bind:class="multi">混合樣式2---複合對象</div>
 42             <!--
 43                 作者:[email protected]
 44                 時間:2019-11-20
 45                 描述:綁定計算屬性
 46             -->
 47             <div v-bind:class="cmpstyle">混合樣式3---計算屬性</div>
 48             <!--
 49                 作者:[email protected]
 50                 時間:2019-11-20
 51                 描述:數組綁定樣式
 52             -->
 53             
 54             <div v-bind:class="arrcss">混合樣式4---數組綁定樣式</div>
 55             <!--
 56                 作者:[email protected]
 57                 時間:2019-11-20
 58                 描述:綁定內聯樣式,直接綁定到一個樣式對象通常更好,這會讓模板更清晰:
 59             -->
 60              <div v-bind:style="{color:bg2}">內聯樣式2--屬性</div>
 61               <div v-bind:style="bg3">內聯樣式3--綁定對象</div>
 62               <!--
 63                   作者:[email protected]
 64                   時間:2019-11-20
 65                   描述:也可以綁定數組
 66               -->
 67                <div v-bind:style="[bg3,bg4]">內聯樣式4--綁定對象</div>
 68         </div>
 69         <script type="text/javascript">
 70             var vm=new Vue({
 71                 el:"#app",
 72                 data:{
 73                     bg:'yellow',
 74                     isbold:true,
 75                     isred:true,
 76                     multi:{
 77                         red:true,
 78                         bold:true,
 79                     },
 80                     arrcss:['red','bold'],
 81                     bg2:'green',
 82                     bg3:{
 83                         color:'red',
 84                         fontSize:'30px'
 85                     },
 86                     bg4:{
 87                         fontStyle:'italic'
 88                     }
 89                 },
 90                 computed:{
 91                     cmpstyle:function(){
 92                         return {
 93                             red:true,
 94                             bold:true,
 95                         }
 96                     }
 97                 }
 98             });
 99         </script>
100     </body>
101 </html>
View Code

備註

不管見識高低,一個人深度整理和收拾自己的內心,這事本身就很迷人。我努力奔跑只為追上曾經被寄予厚望的自己!!!


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

-Advertisement-
Play Games
更多相關文章
  • 簡述問題“統計最新時刻處於某一狀態的設備的數量” 1. 首先子查詢結果,可以看到每個設備最新的狀態信息 2.1 在子查詢的基礎上,對設備狀態進行分組,進行統計每個狀態的設備數量 2.1.1 可以看到處於'火警'狀態的數量是2,沒有問題,但是看下一張圖 2.1.2 可以看到處於'故障'狀態的數量是(n ...
  • [20191218]降序索引疑問4.txt--//前幾天優化一個項目,我發現許多表裡面有有隱含欄位,一般開發很少建立函數索引.我自己檢查發現裡面存在大量的降序索引.--//我感覺有點奇怪,為什麼開發要建立大量降序索引有什麼好處呢?--//我在鏈接http://www.itpub.net/thread ...
  • 本章學習adt安卓打包過程、adb指令學習、並通過adb將打包的APK發給設備 1.打包 在eclipse中已經幫我們實現打包了. 具體打包流程如下: 最終一個APK包含瞭如下: classes.dex文件 (由class編譯過來的) resources.arsc文件 (編譯過的資源文件) Andr ...
  • 1.android中常用名詞介紹 ADT: ADT為Eclipse的插件。為Eclipse和SDK之間起了一個橋梁的作用。 SDK: 軟體開發工具包(Soft Development Kit),它為開發者提供了Android庫文件以及其它開發所用到的工具 JDK: java開發工具包,提供java工 ...
  • 最近在維護項目遇到一些奇葩的問題,自己研究了一下,但並沒有解決,再此做個記錄,路過的大牛還望,出個思路;再此,描述問題,以供大家研討1. MJRefresh 佈局問題ViewController裡面有兩個和self.View 一樣大小的View 一個 是添加了MJRefresh.mj_header ...
  • 我們有時候會向一個方法中傳入一個參數,並且對這個參數做一些處理的操作; 但是因為是引用傳遞,處理過後會對原有的對象造成修改,無法進行反覆使用。 如例子: 兩次列印的結果一模一樣。這樣下一個方法在繼續使用arr這個數的時候就不是["a","b","c"]這個值了,而是["a","b","c",2]; ...
  • HTML代碼 寫一個div來作為滑鼠區域 div中寫一個span顯示坐標信息 <body> <div id=""> <span></span> </div> </body> 給div和span增加樣式並定位 <style type="text/css"> div{ position: relativ ...
  • react中setState方法到底是非同步還是同步,其實這個是分在什麼條件下是非同步或者同步。 1.先來回顧一下react組件中改變state的幾種方式: import React, { Component } from 'react' class Index extends Component { ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...