久久精品国产99国产精品免费看_中文成人在线_日本在线播放视频_精品国产一区二区三区在线观看

v-bind動態綁定樣式 - Vue3新手基礎教程

VUE的動態綁定樣式詳解

數據綁定的一個常見需求場景是操縱元素的 CSS class 列表和內聯樣式。

因為?class?和?style?都是 attribute,我們可以和其他 attribute 一樣使用?v-bind?將它們和動態的字符串綁定。

但是,在處理比較復雜的綁定時,通過拼接生成字符串是麻煩且易出錯的。

因此,Vue 專門為?class?和?style?的?v-bind?用法提供了特殊的功能增強。

除了字符串外,表達式的值也可以是對象或數組。

能動態的修改各類樣式

提要:

  • v-bind:指令會將普通屬性的值變為表達值
  • 使用v-bind指令的class屬性值不再是字符串,而是表達式。 表達式里的className不是一個普通的字符,而是一個變量,Vue實例data屬性中的數據。
  • v-bind 在處理 class 和 style 時, 表達式除了可以使用字符串之外,還可以是對象或數組。
  • v-bind:class?可以簡寫為?:class

v-bind 指令可以讓我們將屬性值關聯到Vuedata數據中,這樣的屬性,我們稱作為屬性的動態綁定
屬性的動態綁定比較符合vue以數據為驅動的模式,如果需要修改那個屬性值,就可以直接通過修改Vue數據即可。

注意:

動態屬性綁定, 在我們需要的時候在使用,如果一個屬性的是是固定的,并不會在未來發生改變,就沒有必要動態綁定屬性.

但在屬性動態綁定過程中有兩個屬性比較特殊,這兩個屬性就是class 和style屬性,

在將 v-bind 用于 classstyle 時,Vue.js 做了專門的增強。

表達式結果的類型除了字符串之外,還可以是對象或數組。

用法示例

<h2 :class="msg">Hello World</h2>

使用動態綁定指令, 那么此時class后面的引號不再是字符串,而是一個JavaScript表達式。

?msg也就成為了一個變量,因此此時h2標簽的類名不是字符串msg, 而是data數據中msg中的值、

演示代碼

    <script src="https://unpkg.com/vue@next"></script>
    <div id="app">

        <!-- 未使用動態綁定的class屬性 -->
        <div class="msg">hello world</div>

        <!-- 使用v-bind 動態綁定class屬性 -->
        <div :class="msg">你好! Vue</div>
    </div>

    <script>
        const App = {
            data() {
                return {
                    msg: 'nbox',
                }
            },
        }
        const app = Vue.createApp(App);
        app.mount("#app");
    </script>
    <style>
        .nbox {
            color: red;
        }
    </style>

瀏覽器執行效果

hello world 你好! Vue
v-bind動態綁定樣式 - Vue3新手基礎教程

??Class

屬性綁定

我們可以為?v-bind:class?設置一個對象,從而動態的切換?class:

<div :class="{ 'active': isActive }"></div>

如果isActive為真,則在瀏覽器中渲染如下

<div class="active"></div>

語法說明:

  1. 上面的語法表示: active 這個 類名是否存在 將取決于數據屬性isActive 的 布爾特性。
  2. 如果 isActive的值為true, 那么div 將有類名active 否則, div沒有box類名
  3. 需要注意,此時active就是一個類名,并不是vue中的數據屬性

多個對象

<div :class="{'active' : isActive, 'text-danger' : hasError}"></div>

瀏覽器渲染

<div class="active text-danger"></div>

與普通的 class 屬性共存

<div class="static" :class="{ 'active' : isActive, 'text-danger' : hasError }"> </div>

瀏覽器渲染

<div class="static active text-danger"></div>

錯誤示例,下列兩個代碼不會生效

<h2 :class="msg box">Hello World</h2>
<h2 
    :class="isTrue ? msg : ''"
    :class="flag ? 'haha' : ''"
>你好</h2>

class綁定對象

如果您的class屬性較多,我推薦您綁定對象,以便您的操作和代碼的整潔性

<div id="app">
    <div  :class="classObject"></div>
</div>
const app = {
    data() {
      return {
         classObject: {
            'active': false,
            'text-danger': true
         }
      }
   }
}

瀏覽器渲染

<div class="text-danger"></div>

綁定一個返回對象的計算屬性。這是一個常用且強大的模式

<div id="app">
    <div  :class="classObject"></div>
</div>
        const app = {
            data() {
                return {
                    isActive: true,
                    error: false,
                }
            },
            computed: {
                classObject() {
                    return {
                        active: this.isActive,
                        'text-danger': !this.error,
                    }
                }
            }
        }

瀏覽器渲染

<div class="active text-danger"></div>

class綁定數組(方法一)

<div id="app">
    <div class="static" :class="[activeClass, errorClass]"></div>
</div>
const app = {
    data() {
        return {
            activeClass: 'active',
            errorClass: 'text-danger'
        }
    }
}

class綁定數組(方法二)

<div :class="classObject"></div>
        const App = {
            data() {
                return {
                    classObject: ["static", "active", { "text-danger": true }],
                }
            },
        }

以上兩種方法,瀏覽器渲染均為

<div class="static active text-danger"></div>

使用三元表達式來切換列表中的 class

<div id="app">
    <div :class="[isActive ? activeClass : '', errorClass]"></div>
</div>
const app = {
    data() {
        return {
            isActive: false,
	    activeClass: 'active',
	    errorClass: 'text-danger'
        }
    }
}

瀏覽器渲染為

<div class="text-danger"></div>

在代碼isActive ? activeClass : ''中,因為isActive是假,表達式的值為第三個,為空值,當isActive為真時,表達式的值為第二個,即為activeClass

??style(內聯樣式)

動態綁定style屬性說明:

  1. 如果使用動態綁定屬性方法綁定行內樣式,那么style屬性值將不再是字符串,而是表達式,
  2. 動態綁定style的值既然是表達式,那么就可以在表達式中使用對象.
  3. 如果值為對象,那么對象的屬性名則為CSS樣式屬性, 值為樣式的值。
  4. 注意,此時對象中的屬性值,可以是確定的樣式值,也可以是vue的數據變量,
  5. 因此有些值不能再像style標簽中一樣書寫,例如50px,以前使用不加引號,現在必須加引號

對象寫法關于值的問題

如果使用動態綁定屬性style里的對象值不加引號, 就會有如下的問題:

<h2 :style="{color:red,font-size:30px}">Hello World</h2>

上面的這種寫法就會報錯,?red30px會被當做變量去Vue data屬性中找對應的數據, 但是找不到就報錯

正確的寫法應該是這樣的

<h2 :style="{color:'red',fontSize:'30px'}">Hello World</h2>

也能正確顯示結果, 但是要注意字符串嵌套問題

v-bind動態綁定樣式 - Vue3新手基礎教程

對象寫法的屬性問題:

相信通過剛才的例子,你也發現了,我們發font-size 的寫法改為了fontSize.

因為CSS 屬性名可以用駝峰式 (camelCase) 或短橫線分隔 (kebab-case) 都可以:

因此,在普通的style屬性中一下兩種寫法都可以

<!-- 駝峰式 (camelCase) 寫法 --->
<h2 style="color:red;fontSize:30px;">Hello World</h2>

<!-- 短橫線分隔 (kebab-case --->
<h2 style="color:red;font-size:30px;">Hello World</h2>

兩種處理方法:

  1. 駝峰式 (camelCase)
  2. 如果要使用連字符, 就需要添加雙引號, 將屬性變成字符串的寫法

因此動態綁定需要如下寫法

<!-- 駝峰式 (camelCase) 寫法 --->
<h2 :style="{color:'red', fontSize:'30px'}">Hello World</h2>

<!-- 短橫線分隔 (kebab-case) 但是要加引號 --->
<h2 :style="{color:'red', 'font-size' :'30px'}">Hello World</h2>

推薦用駝峰寫法, 對象的值也可以是變量

示例代碼

<div id="app">
    <div :style="{ color: activeColor, fontSize: fontSize + 'px' }">菜鳥教程</div>
</div>

<script>
const app = {
    data() {
        return {
            activeColor: 'red',
	    fontSize: 30
        }
    }
}

Vue.createApp(app).mount('#app')
</script>

瀏覽器渲染

<div style="color: red; font-size: 30px;">菜鳥教程</div>

style綁定對象(推薦)

代碼

<div id="app">
    <div :style="styleObject">菜鳥教程</div>
</div>

<script>
const app = {
    data() {
        return {
		styleObject: {
                color: "red",
	        fontSize: "30px"
			}
        }
    }
}

Vue.createApp(app).mount('#app')

瀏覽器渲染

<div style="color: red; font-size: 30px;">菜鳥教程</div>

同樣的,如果樣式對象需要更復雜的邏輯,也可以使用返回樣式對象的計算屬性。

動態修改樣式

代碼

    <script src="https://unpkg.com/vue@next"></script>
    <div id="app">
        <h2 :style="styleObject">Hello World</h2>
        <button @click="changColor">點擊切換顏色</button>
    </div>

    <script>
        const App = {
            data() {
                return {
                    styleObject: {
                        color: "red",
                        fontSize: "30px"
                    }
                }
            },
            methods: {
                changColor() {
   this.styleObject.color = this.styleObject.color == "red" ? "skyblue" : "red"
                }
            }
        }
        const app = Vue.createApp(App);
        app.mount("#app");
    </script>

瀏覽器運行效果

Hello World

style綁定數組

可以擴展對象的用法,給動態屬性的值綁定為數組,數組中就可以使用多組樣式對象來綁定CSS樣式。

這些對象會被合并后渲染到同一元素上:

代碼

<div id="app">
    <div :style="[baseStyles, overridingStyles]">菜鳥教程</div>
</div>

<script>
const app = {
    data() {
        return {
		baseStyles: {
                color: 'green',
                fontSize: '30px'
            },
	        overridingStyles: {
                'font-weight': 'bold'
            }
        }
    }
}

Vue.createApp(app).mount('#app')

瀏覽器渲染

<div style="color: green; font-size: 30px; font-weight: bold;">菜鳥教程</div>

注意:

當?v-bind:style?使用需要特定前綴的 CSS 屬性時,如 transform ,Vue.js 會自動偵測并添加相應的前綴。

自動前綴

當你在?:style?中使用了需要瀏覽器特殊前綴的 CSS 屬性時,Vue 會自動為他們加上相應的前綴。Vue 是在運行時檢查該屬性是否支持在當前瀏覽器中使用。如果瀏覽器不支持某個屬性,那么將測試加上各個瀏覽器特殊前綴,以找到哪一個是被支持的。

多重值

可以為 style 綁定中的 property 提供一個包含多個值的數組,常用于提供多個帶前綴的值,例如:

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

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

??組件

單個根元素的自定義組件

當你在帶有單個根元素的自定義組件上使用 class 屬性時,這些 class 將被添加到該元素中。此元素上的現有 class 將不會被覆蓋。

<div id="app">
    <runoob class="classC classD"></runoob>
</div>
app.component('runoob', {
    template: '<h1 class="classA classB">I like runoob!</h1>'
})

瀏覽器渲染

<h1 class="classA classB classC classD">I like runoob!</h1>

帶數據綁定此元素上的現有 class 將不會被覆蓋。

<my-component :class="{ active: isActive }"></my-component>

渲染(isActive為真)

<p class="active">Hi</p>

多個根元素

如果你的組件有多個根元素,你需要定義哪些部分將接收這個類。可以使用?$attrs?組件屬性執行此操作:

<script src="https://unpkg.com/vue@next"></script>
<style>
.classA {
    color: red;
	font-size:30px;
}
</style>

<div id="app">
    <runoob class="classA"></runoob>
</div>
 
<script>
const app = Vue.createApp({})
 
app.component('runoob', {
  template: `
    <p :class="$attrs.class">I like runoob!</p>
    <span>這是一個子組件</span>
  `
})
 
app.mount('#app')
</script>

注意:template 中?`?是反引號,不是單引號?'

瀏覽器渲染

<div id="app">
<p class="classA">I like runoob!</p>
<span>這是一個子組件</span></div>

拓展想象

若是配合CSS變量,豈不是有無限可能

通過element的ColorPicker 顏色選擇器修改文本顏色

參考文檔

給TA贊賞
共{{data.count}}人
人已贊賞
??
Npcink上的部份代碼及教程來源于互聯網,僅供網友學習交流,若您喜歡本文可附上原文鏈接隨意轉載。
無意侵害您的權益,請發送郵件至 1355471563#qq.com 或點擊右側 私信:Muze 反饋,我們將盡快處理。
?
購物車
優惠劵
搜索
久久精品国产99国产精品免费看_中文成人在线_日本在线播放视频_精品国产一区二区三区在线观看

    9000px;">

      欧美日韩不卡一区二区| 成人黄色一级视频| 成人国产一区二区三区精品| 日韩欧美国产三级| 国模一区二区三区白浆 | 日韩vs国产vs欧美| 日韩欧美国产小视频| 不卡视频在线观看| 亚洲综合男人的天堂| 欧美日本韩国一区| 国产精品一区二区久激情瑜伽| 国产精品无遮挡| 日本高清无吗v一区| 无码av中文一区二区三区桃花岛| 日韩免费看网站| 91麻豆免费观看| 精品一区二区三区的国产在线播放| 国产精品理论在线观看| 91麻豆精品国产91久久久久久久久| 另类人妖一区二区av| 国产精品不卡视频| 91精品婷婷国产综合久久| 成人午夜免费av| 日韩电影在线观看一区| 国产精品视频第一区| 5566中文字幕一区二区电影| jizz一区二区| 国产一区美女在线| 污片在线观看一区二区| 日韩理论片在线| 久久色.com| 91精品国产色综合久久久蜜香臀| 播五月开心婷婷综合| 国产又黄又大久久| 日韩精品久久久久久| 亚洲图片另类小说| 欧美国产成人在线| 久久天堂av综合合色蜜桃网| 日韩女同互慰一区二区| 在线中文字幕不卡| 91热门视频在线观看| 国产成人午夜精品5599| 精品在线亚洲视频| 日本成人超碰在线观看| 婷婷综合久久一区二区三区| 亚洲一区二区在线播放相泽| 国产精品黄色在线观看| 国产精品私房写真福利视频| 国产亚洲制服色| 久久―日本道色综合久久| 欧美mv日韩mv国产网站| 日韩一区二区三区av| 欧美一区午夜视频在线观看| 在线电影国产精品| 91精品在线观看入口| 日韩一区和二区| 欧美一区二区二区| 欧美一级理论性理论a| 91精品国产福利在线观看| 欧美一级高清片| 久久女同精品一区二区| 中文字幕欧美国产| 一区在线观看视频| 一区二区三区中文字幕| 夜夜精品视频一区二区| 午夜精品一区二区三区电影天堂| 视频一区二区中文字幕| 琪琪一区二区三区| 精品一区二区三区日韩| 国产真实乱偷精品视频免| 国产乱码精品一区二区三区忘忧草 | 亚洲欧美韩国综合色| 一区二区在线观看免费视频播放| 亚洲视频一区二区在线观看| 一区二区在线看| 奇米影视一区二区三区小说| 国产一区二区视频在线| aaa欧美色吧激情视频| 欧美系列在线观看| 久久一夜天堂av一区二区三区 | 美美哒免费高清在线观看视频一区二区| 日本不卡视频在线| 国产成人8x视频一区二区| 91蜜桃在线免费视频| 欧美一区二区女人| 中文字幕在线不卡一区二区三区| 亚洲另类春色国产| 精品一区二区三区香蕉蜜桃| 99在线精品观看| 精品剧情在线观看| 亚洲另类一区二区| 国产精品亚洲午夜一区二区三区| 欧美日韩一本到| 国产精品毛片大码女人| 三级亚洲高清视频| 91丝袜国产在线播放| 久久久精品2019中文字幕之3| 亚洲国产精品人人做人人爽| 成人性生交大合| 日韩欧美在线网站| 亚洲午夜免费视频| 99热这里都是精品| 中国色在线观看另类| 另类小说色综合网站| 欧美日本国产视频| 亚洲精品免费在线播放| 成人毛片在线观看| 26uuu色噜噜精品一区二区| 午夜精品福利久久久| 在线观看亚洲a| 国产精品萝li| 国产精品亚洲一区二区三区妖精 | 日韩欧美一区二区不卡| 亚洲最大的成人av| 成人国产精品视频| 国产日韩成人精品| 国产伦理精品不卡| 久久久国产一区二区三区四区小说 | 欧洲日韩一区二区三区| 中文字幕亚洲视频| av中文字幕在线不卡| 久久精品日韩一区二区三区| 狠狠色丁香久久婷婷综| 欧美大片免费久久精品三p| 五月激情综合婷婷| 日韩亚洲欧美中文三级| 蜜臀久久久99精品久久久久久| 欧美日韩电影一区| 美女免费视频一区| 日韩午夜精品电影| 久久国产精品第一页| 日韩欧美综合一区| 激情小说亚洲一区| 日本一区二区三区在线不卡| av午夜一区麻豆| 亚洲激情图片小说视频| 在线一区二区三区| 亚洲大尺度视频在线观看| 8v天堂国产在线一区二区| 蜜臀av在线播放一区二区三区| 日韩一区二区三区电影| 国产美女精品人人做人人爽| 欧美激情一区二区| 色哟哟日韩精品| 亚洲电影你懂得| 精品久久国产字幕高潮| 国产成人精品免费看| 一区二区三区欧美久久| 欧美一区二区三区的| 国产91精品免费| 亚洲在线成人精品| 欧美不卡在线视频| 972aa.com艺术欧美| 天堂久久一区二区三区| 国产亚洲自拍一区| 欧美在线观看视频在线| 精品在线播放午夜| 中文字幕中文乱码欧美一区二区| 欧美精品一二三区| 丁香婷婷综合色啪| 午夜欧美电影在线观看| 国产三级一区二区三区| 欧美日韩在线免费视频| 国产高清在线精品| 一区二区三区不卡在线观看| 日韩欧美国产wwwww| 91一区二区在线观看| 国产呦萝稀缺另类资源| 亚洲一区在线观看视频| 国产亚洲欧美色| 欧美电影影音先锋| 91视视频在线观看入口直接观看www | 91丨九色丨黑人外教| 九色porny丨国产精品| 亚洲综合色噜噜狠狠| 国产日韩精品视频一区| 欧美不卡在线视频| 在线不卡一区二区| 色噜噜狠狠色综合欧洲selulu| 国产一区二三区| 视频在线在亚洲| 一区二区三区四区高清精品免费观看| 欧美激情综合五月色丁香| 日韩三级视频在线观看| 欧美日韩国产系列| 欧美做爰猛烈大尺度电影无法无天| 国产成人综合亚洲91猫咪| 日本vs亚洲vs韩国一区三区| 亚洲成a人在线观看| 亚洲精品国产高清久久伦理二区| 久久久九九九九| 欧美激情一区二区在线| 久久久精品tv| 国产色综合久久| 欧美极品aⅴ影院| 日本一区二区三区视频视频| 欧美高清在线一区二区| 国产精品成人免费在线| 亚洲卡通动漫在线| 亚洲国产精品一区二区www在线|