Vue.js中對css的操作(修改)具體方式詳解

使用v-bind:class或者v-bind:style或者直接通過操作dom來對其樣式進行更改;

創(chuàng)新互聯(lián)建站長期為上千余家客戶提供的網站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網生態(tài)環(huán)境。為岱岳企業(yè)提供專業(yè)的網站設計、做網站,岱岳網站改版等技術服務。擁有10多年豐富建站經驗和眾多成功案例,為您定制開發(fā)。

1.v-bind:class || v-bind:style

其中v-bind是指令,: 后面的class 和style是參數(shù),而class之后的指在vue的官方文檔里被稱為'指令預期值'(這個不必深究,反正個人覺得初學知道他叫啥名有啥用就好了)同v-bind的大多數(shù)指令(部分特殊指令如V-for除外)一樣,除了可以綁定字符串類型的變量外,還支持一個單一的js表達式,也就是說v-bind:class的'指令預期值'除了字符串以外還可以是對象或者數(shù)組(‘v-bind:'中的v-bind可省略)。

1.1:對象語法:

通過對象來綁定v-bind:class=“{'css類名':控制是否顯示(true or false)}”

<template>
 <div>
 <div class='mycolor' :class="{'colordisplay':display}"><span>1.1我的對象更改&&綁定test</span></div>
 </div>
</template>
<script>
 export default {
 name: 'mytest',
 data() {
 return {
 display: true
 }
 },
 mounted() {},
 computed: {},
 methods:{}
 }
</script>
<style>
 .colordisplay {
 display: inline;
 background: red;
 border: 1px solid blue
 }
</style>

如果display為true,那么此時該部分的class就是 class="mycolor colordisplay",通過設置display的值就可以控制colordisplay的顯示

如果要設置綁定多個class的話就和正常的對象鍵值對一樣中間用逗號隔開就可以了v-bind:class="{'colordisplay':display,'ispay':pay}"

1.2:內聯(lián)樣式:

v-bind:style='mycolor'

template

<div :style='mypagestyle'><span>1.2我的樣式內聯(lián)更改&&綁定test</span></div>

data

mypagestyle:{color: 'yellow',background:"blue"},

1.3:數(shù)組語法:

也可以通過數(shù)組來綁定v-bind:style='[mycolor1,mycolor2]'

<div :><span>1.3我的數(shù)組更改&&綁定test</span></div>

 然后設置返回的數(shù)據(jù)為

myarr:{color: 'white'},
myarrtest:{background:'#000',display:'inline'},

2.計算屬性

也可以通過計算屬性計算(適用于較為復雜判斷)樣式

<div class='computed' :class='compuretu'>2.計算屬性判斷</div>

將計算屬性的返回值作為類名,通過判斷serd和slid的值來控制樣式的顯示與否

 data() {
 return {serd:true,slid:true}
 }, 
 computed: {
 compuretu: function() {
 return {compuretu: this.serd && this.slid}
 }
 }

設置樣式

.compuretu{color:white;background: red}

3.操作節(jié)點

由于vue本身是虛擬dom如果通過document來進行節(jié)點樣式更改的時候有可能會出現(xiàn)'style' is not definde的錯誤,

這個問題的解決方式就必須得對vue 的理解要求更高一層了,它可以通過在vue本身的周期mounted函數(shù)里用ref和$refs 來獲取樣式,來完成對其樣式的更改:示例如下:

<template>
<div>
<div style=“color: green;” ref="abc"><span>我的test</span></div>
</div>
</template>
<script>
export default {
name: 'mytest',
data() {
return {}
},
mounted() {console.log(this.$refs.abc.style.cssText)}
}
<script>
<style>
</style>

說明:

1.ref被用來給元素(子組件)注冊引用信息;

2.vm.$refs 一個對象,持有已注冊過 ref 的所有子組件(或HTML元素);

使用:在 HTML元素 中,添加ref屬性,然后在JS中通過vm.$refs.屬性來獲取

上述會將style的內容全部輸出(color: green;)

這樣的話對其進行更改就可以對相應的屬性直接更改(this.$refs.abc.style.color=red

<template>
 <div>
 <div :class='{mycss}'><span>我的單個class屬性的test</span></div>
 <div class='mycolor' :class="{'colordisplay':display}"><span>1.1我的對象更改&&綁定test</span></div>
 <div :style='mypagestyle'><span>1.3我的樣式內聯(lián)更改&&綁定test</span></div>
 <div :><span>1.3我的數(shù)組更改&&綁定test</span></div>
 <div class='computed' :class='compuretu'>2.計算屬性判斷</div>
 <div  ref="abc"><span>3.我的dom更改test</span></div>
 </div>
</template>
<script>
 export default {
 name: 'mytest',
 data() {
 return {
 serd:true,
 slid:true,
 mycss: {
  color: ''
 },
 mypagestyle:{
  color: 'yellow',
  background:"blue"
 },
 myarr:{
  color: 'white'
 },
 myarrtest:{
  background:'#000',
  display:'inline'
 },
 display: true
 }
 },
 mounted() {  
 console.log(this.$refs.abc.style.cssText)
 this.$refs.abc.style.color = 'red' //修改屬性
 this.$refs.abc.style.background = 'black' //新增屬性
 this.$refs.abc.style.display = 'inline' 
 console.log(111) 
 console.log(this.$refs.abc.style.display) 
 },
 computed: {
 compuretu: function() {
 return {
  compuretu: this.serd && this.slid
 }
 }
 },
 methods:{
 
 }
 }
</script>
<style>
 .mycss {
 color: blue
 }
 
 .colordisplay {
 display: inline;
 background: red;
 border: 1px solid blue
 }
 
 .mycolor {
 color: orange
 }
 
 .computed {
 border: 1px solid yellow
 }
 .compuretu{
 color:white;
 background: red;
 }
</style>

當然最后這種方式對于初入門的朋友來講可能會有點理解不透,所以我更建議大家使用前幾種方式

總結

以上所述是小編給大家介紹的Vue.js中對css的操作(修改)具體方式詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網站的支持!

分享題目:Vue.js中對css的操作(修改)具體方式詳解
網頁路徑:http://bm7419.com/article8/jceoop.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化、企業(yè)建站、網站內鏈、App開發(fā)、手機網站建設服務器托管

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網站制作