久久精品国产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;">

      日韩一级高清毛片| 精品一区中文字幕| 国产日韩三级在线| 亚洲久草在线视频| 国产精品12区| 正在播放亚洲一区| 天天色 色综合| 91老师片黄在线观看| 欧美日本乱大交xxxxx| 国产精品久久久久影院色老大| 蜜臀av亚洲一区中文字幕| 欧美久久久影院| 免费xxxx性欧美18vr| 日韩欧美一区二区三区在线| 亚洲欧美激情一区二区| 成人性生交大片免费看视频在线 | 日本麻豆一区二区三区视频| 波波电影院一区二区三区| 国产精品麻豆视频| 国产成人精品综合在线观看 | 日韩精品91亚洲二区在线观看| 国产乱妇无码大片在线观看| 精品国产一区二区精华| 精品一区二区在线视频| 精品成人一区二区| 国产在线精品一区二区不卡了| 欧美日韩国产免费一区二区| 日日摸夜夜添夜夜添国产精品| 色综合天天综合色综合av| 国产精品拍天天在线| 成人av手机在线观看| 亚洲视频一二三区| 欧美性极品少妇| 日本成人中文字幕| 久久影院午夜论| 成人一级视频在线观看| 九色porny丨国产精品| 精品国产乱码久久久久久浪潮 | 欧美日韩精品一区二区三区| 国产在线一区观看| 免费精品视频在线| 国产精品超碰97尤物18| 欧美亚洲国产怡红院影院| 日日夜夜一区二区| 亚洲国产精品一区二区久久恐怖片| 一区二区三区av电影| xnxx国产精品| 成人av电影免费在线播放| 亚洲一区二区三区四区在线免费观看| 欧美成人一区二区三区在线观看| 99久久777色| 日韩制服丝袜av| 亚洲丝袜精品丝袜在线| 国产精品免费视频一区| 欧美日本在线观看| 成人午夜免费电影| 偷偷要91色婷婷| 欧美又粗又大又爽| 亚洲影院久久精品| 欧美一卡二卡在线观看| 国产a级毛片一区| 久久精品国产精品亚洲红杏| 一级中文字幕一区二区| 亚洲国产你懂的| 亚洲最快最全在线视频| 日韩一区在线看| 国产精品嫩草影院av蜜臀| 久久综合色之久久综合| 日韩写真欧美这视频| 91在线播放网址| 69久久夜色精品国产69蝌蚪网| 国产一区二区三区国产| 精品sm在线观看| 91精品国产丝袜白色高跟鞋| 色综合久久中文综合久久97| 欧美日韩亚洲综合在线| 成人黄色免费短视频| 一本色道综合亚洲| 91精品欧美福利在线观看| 久久品道一品道久久精品| 国产欧美日韩在线看| 1024亚洲合集| 亚洲香肠在线观看| 国产一级精品在线| 91麻豆精品秘密| 国产欧美一区二区三区沐欲| 亚洲三级久久久| 国产精品国产三级国产aⅴ无密码| 国产精品素人视频| 午夜精品久久久| 色菇凉天天综合网| 精品视频123区在线观看| 精品区一区二区| 国产精品初高中害羞小美女文| 亚洲欧美一区二区视频| 裸体在线国模精品偷拍| 成人丝袜18视频在线观看| 欧美日韩一区二区三区四区| 国产欧美综合色| 国产一区二区精品在线观看| av一区二区三区四区| 久久久久国产精品麻豆ai换脸| 夜夜揉揉日日人人青青一国产精品 | 欧美亚洲高清一区| 亚洲精品一线二线三线无人区| 中文字幕精品三区| 国产精品1区2区| 91精品国产91久久久久久一区二区| 亚洲一二三四区| 日本道精品一区二区三区| 久久色.com| 国产成人在线视频播放| 国产亚洲欧美一级| 91亚洲午夜精品久久久久久| 亚洲精品国产视频| 欧洲另类一二三四区| 视频一区视频二区中文字幕| 久久午夜电影网| 色综合亚洲欧洲| 国产在线精品一区二区| 欧美一区二区三区视频在线| 国产精品自在在线| 亚洲成a人v欧美综合天堂| 久久久久久久久久久久久久久99 | 精品国产欧美一区二区| 99re这里只有精品视频首页| 男人的j进女人的j一区| 国产精品久久夜| 亚洲综合视频在线| 国产精品五月天| 国产一区二区看久久| 欧美日韩dvd在线观看| 成人动漫一区二区在线| 国产在线麻豆精品观看| 亚洲国产精品久久久久婷婷884| 免费成人av在线| 另类小说图片综合网| 一本一本久久a久久精品综合麻豆| 精品一区二区成人精品| 日韩成人免费电影| 水蜜桃久久夜色精品一区的特点| 亚洲日本在线天堂| 亚洲免费观看高清完整版在线观看 | 奇米影视一区二区三区| 日韩三区在线观看| 91视频免费看| 久久99久久久欧美国产| 亚洲综合色丁香婷婷六月图片| 久久众筹精品私拍模特| 8x8x8国产精品| 欧美在线观看18| 91麻豆视频网站| 国产 欧美在线| 国产麻豆成人传媒免费观看| 视频在线观看一区二区三区| 亚洲一区二区影院| 91丨porny丨户外露出| 丰满少妇在线播放bd日韩电影| 日本特黄久久久高潮| 亚洲男人天堂av网| 亚洲欧洲av在线| 亚洲国产精品激情在线观看| 日韩视频一区二区在线观看| 在线观看国产日韩| 欧洲国产伦久久久久久久| 性做久久久久久| 五月天中文字幕一区二区| 日韩黄色免费网站| 中文字幕欧美国产| 欧美一区二区三区喷汁尤物| 国产.精品.日韩.另类.中文.在线.播放 | 国产白丝精品91爽爽久久| 精品国产一区久久| 中日韩av电影| 一区二区久久久久久| 亚洲成人免费视| 九色综合国产一区二区三区| 国产成人高清在线| 色欧美片视频在线观看| 欧美日韩国产精选| 久久午夜电影网| 亚洲高清视频的网址| 韩国理伦片一区二区三区在线播放 | 欧美少妇bbb| 26uuu国产一区二区三区| 国产精品成人一区二区三区夜夜夜| 一区二区三区美女视频| 国产综合色精品一区二区三区| 91片黄在线观看| 久久久无码精品亚洲日韩按摩| 亚洲美女在线国产| 国产高清无密码一区二区三区| 欧美性猛交xxxx乱大交退制版| 国产欧美日韩一区二区三区在线观看| 亚洲综合久久av| 成人午夜视频福利| 国产色产综合产在线视频| 免播放器亚洲一区| 欧美色中文字幕| 中文字幕亚洲成人|