久久精品国产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 顏色選擇器修改文本顏色

參考文檔

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

    9000px;">

      九九热久久免费视频| 国产在成人精品线拍偷自揄拍| 亚洲一级理论片| 91视频免费看片| 国产 日韩 欧美 精品| 国产精品乱码一区二区视频| 精品国精品国产自在久不卡| 久久久久亚洲av成人网人人软件| 全部毛片永久免费看| 无码人妻丰满熟妇精品区| 中文字幕人妻精品一区| 99国产精品99| 国产又粗又猛又黄视频| 人妻精品一区二区三区| 一区二区三区福利视频| 亚洲中文一区二区| 国产一级视频在线播放| 欧美亚洲日本在线| 中文在线最新版天堂| 99久久久久成人国产免费| 国产乱淫a∨片免费观看| 免费看的黄色录像| 在线观看免费国产视频| 懂色av.com| 欧美国产成人精品一区二区三区| 亚洲av无码一区二区三区人| japanese国产| 六月婷婷七月丁香| 亚洲成a人无码| 丰满少妇高潮一区二区| 欧美日韩偷拍视频| 最近中文字幕免费视频| 国产精品久久久久野外| 日本激情一区二区| 亚洲欧美一区二区三区在线观看| 国产毛片毛片毛片毛片毛片毛片| 欧美特黄一级片| 亚洲乱熟女一区二区| 国产一级片久久| 亚洲va综合va国产va中文| 啊啊啊国产视频| 欧美做受高潮6| 91精品国产闺蜜国产在线闺蜜| 精品999在线| 在线观看中文字幕视频| 国产精欧美一区二区三区白种人 | 精品成人av一区二区三区| 肉色超薄丝袜脚交69xx图片| 91精品又粗又猛又爽| 久久青青草原亚洲av无码麻豆| 依人在线免费视频| 国产一级做a爱片久久毛片a| 无码人妻久久一区二区三区蜜桃 | 中文精品久久久久人妻不卡| 国产免费999| 亚洲aaa视频| 国精品人伦一区二区三区蜜桃 | 国内自拍视频一区| 一区二区久久精品66国产精品| 国产巨乳在线观看| 一区二区在线观看免费视频| 激情综合丁香五月| 亚洲熟女www一区二区三区| 老司机福利在线观看| 69视频免费看| 日韩和一区二区| 国产精品日日摸夜夜爽| 制服丝袜第二页| 蜜桃av.com| www.com.av| 亚州视频一区二区三区| 精品二区在线观看| 亚洲一级理论片| 日本一本高清视频| 国产免费一区二区三区四区| 中文在线资源天堂| 欧美熟妇另类久久久久久多毛| 成年人二级毛片| 在线不卡一区二区三区| 玖玖爱这里只有精品| 99精品视频免费版的特色功能| 日韩黄色一区二区| 国产又粗又爽视频| 99re6在线观看| 亚洲爆乳无码一区二区三区| 久久精品亚洲无码| 第一页在线视频| 中文字幕福利视频| 日韩av电影网| 久草视频精品在线| 成人av一区二区三区在线观看| 亚洲第一成年人网站| 欧美国产日韩在线视频| 国产日韩久久久| 一本大道伊人av久久综合| 五月天中文字幕| 欧美日韩久久婷婷| 国产一级理论片| jizz中国少妇| 亚洲精品中文字幕乱码三区91| 少妇熟女视频一区二区三区| 精品一区二区三区四区五区六区| www.五月激情| 亚洲人人夜夜澡人人爽| 亚洲二区在线播放| 少妇高潮av久久久久久| 蜜臀精品一区二区三区| 国产资源中文字幕| 成人综合久久网| 一级二级三级视频| 亚洲av成人精品一区二区三区在线播放| 麻豆精品免费视频| 精品国产大片大片大片| 国产精品 欧美 日韩| 95视频在线观看| 亚洲精品91在线| 在线观看国产精品一区| 婷婷在线免费观看| 日韩中文字幕在线观看视频| 欧美 日韩 国产 在线| 久久精品一区二区三区四区五区| 国产免费a视频| 国产传媒国产传媒| 国产av自拍一区| www.亚洲激情| 波多野结衣国产精品| 9999热视频| 99视频免费看| a在线观看免费视频| 91最新在线观看| 99re久久精品国产| 99久久夜色精品国产亚洲| 91福利视频免费观看| 7799精品视频天天看| 91中文字幕永久在线| av网页在线观看| 国产av一区二区三区精品| 丁香激情五月少妇| 国产毛片毛片毛片毛片| 国产又粗又黄又爽的视频| 国产在线一卡二卡| 九九视频免费观看| 久久久久久久久毛片| 欧美成人精品欧美一级| 日本视频网站在线观看| 日韩欧美国产另类| 无码人妻精品一区二区三区夜夜嗨 | 日本免费一区视频| 三级小视频在线观看| 天天插天天操天天射| 羞羞在线观看视频| 亚洲黄色免费观看| 91丨porny丨九色| 成人h动漫精品一区二区无码| 国产黄色网址在线观看| 国产又粗又猛又爽又黄的| 久久久久久久久影院| 欧美一级xxxx| 天堂网在线观看视频| 中文字幕日本人妻久久久免费| 亚洲精品一区二区三区影院忠贞| 91精品无人成人www| 国产精品1234区| 久久黄色免费网站| 日韩不卡一二三| 中文字幕精品亚洲| 99久久精品国产一区色| 国产精选第一页| 美女网站视频黄色| 无套白嫩进入乌克兰美女| 中文字幕激情视频| av在线天堂网| 黄色成人免费看| 日韩欧美中文视频| 中文字幕一区久久| 国产丰满美女做爰| 刘亦菲毛片一区二区三区| 无码人妻av免费一区二区三区 | 一区二区国产精品精华液| 亚洲精品无码久久久| 国产69精品久久久久久久久久| 国产一二三四在线视频| 欧美自拍第一页| 中文字幕人妻无码系列第三区| 波多野结衣激情视频| 久久久久9999| 一区二区三区www污污污网站| 99鲁鲁精品一区二区三区| 韩国中文字幕av| 手机看片国产日韩| 亚洲中文一区二区三区| 韩国一区二区三区四区| 神马久久精品综合| 91日韩精品视频| 久久综合亚洲色hezyo国产| 中国免费黄色片| 国产喷水在线观看| 天天干中文字幕| 成年人网站在线观看视频| 你懂的国产在线|