Summary of various methods for Vue to achieve dynamic styles

Summary of various methods for Vue to achieve dynamic styles

1. Ternary operator judgment

<text :style="{color:state?'#ff9933':'#ff0000'}">hello world </text>
<script>
export default {
	data() {
		return {
			state: true
		}
	}
}
</script>

2. Dynamically set class

2.1 Mainly used for: When clicking in a loop list, the corresponding element is highlighted; (the first element is highlighted by default)

<template>
	<div class="wrapper" v-for="(item,index) in houseList" :key="index" @click="rightTap(index)">
		<div class="houseTitle" :class="{'active' : index === rightIndex}">
			{{item.name}}
		</div>
	</div>
</template>
<script>
export default {
	data() {
		return {
			rightIndex:0,
			houseList:[]
		};
	},
	methods:{
		rightTap(index){ 
			this.rightIndex = index
		}
	}
}
</script>
<style lang="scss" scoped>
.wrapper{
	width: 118px;
	height: 60px;
	margin: 6px auto 0 auto;
	.houseTitle{
		font-size: 22px;
		text-align: center;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.active{
		color:#2a7ffa;
		 background-color: pink;
	}
}
</style>

2.2 Mainly used for: setting corresponding styles for specific values;

  <div 
    :class="activeId === item.id?'activeStyle':'machineBar'" 
    v-for="(item,index) in List" :key="index" @click="clickEvent">    
      <p>{{item.name}}</p>    
  </div>

3. Method judgment

3.1 Mainly used for: setting corresponding styles for different data values;

<template>
  <div v-for="(item,index) in houseList" :key="index">             
     <div :style="getStyle(item.status)">{{item.name}}</div>    
  </div> 
</template>
<script>
export default { 
  data(){
    return {
	  houseList:[
        { 
          id:1,
          name:1,
          status:'a'
        },{
          id:2,
          name:2,
          status:'b'
        },{
          id:3,
          name:3,
          status:'c'
        }
      ]
    }
  },
  methods:{
    getStyle(e){        
      console.log('value',e)        
      if(e === 'a'){            
        return {                
          width:'60px',
          height:'60px',                
          background:'yellow',                 
          margin: '10px auto'             
        }        
      }else if(e === 'b'){            
        return {                
          width:'60px',
          height:'60px',                  
          background:'red',                 
          margin: '10px auto'            
        }        
      }else if(e === 'c'){            
        return {                
          width:'60px',
          height:'60px',                 
          background:'pink',                 
          margin: '10px auto'             
        }        
      }
    }
  }
}
</script>

3.2 Mainly used for: displaying corresponding styles under multiple element events;

<template>
  <div 
      class="homeWrap" :class="{'select': selected === 1,'click': clicked === 1}" 
      @click="handleClick(1)" @mousedown="menuOnSelect(1)">
     Home page   
</template>
<script>
export default {
  return {
      selected: 0,
      clicked: 0
  }
  methods:{
    menuOnSelect(value){
      this.selected = value;
    },
    handleClick(value){
      this.selected = 0
      this.clicked = value
    }
  }
 }
</script>
<style lang="stylus" scoped>
  .homeWrap.select 
    background red
  .homeWrap.click 
    background yellow
</style>

4. Array Binding

<div :class="[isActive,isSort]"></div>
// Combine the array with the ternary operator to determine the required class
<div class="item" :class="[item.name? 'lg':'sm']"></div>
<div class="item" :class="[item.age<18? 'gray':'']"></div>
// Array object combined with <div :class="[{ active: isActive }, 'sort']"></div>

data() {
  return {
    isActive:'active',
    isSort:'sort'
 }
}
// css
.active{
    /*Write the first style you need to set here*/
  } 
.sort{
    /*Write the second style that needs to be set here*/
  }

5. Computed property name method combined with es6 object

 <div :class="classObject"></div>
 
  export default {
    data(){
      return {
        isActive:true
      }
    },
    computed:{
      classObject() {
        return {
          class_a:this.isActive,
          class_b:!this.isActive
        // This needs to be modified and filled in according to the situation of your own project}
      }
    }
  }
 
// css
.class_a{
    /*Write the first style you need to set here*/
}
 
.class_b{
   /*Write the second style that needs to be set here*/
 }

The above is the detailed content of the various methods of Vue to achieve dynamic styles. For more information about Vue to achieve dynamic styles, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Detailed explanation of the method code for dynamically binding class and style in Vue
  • Summary of Vue.js style dynamic binding implementation
  • Vue implements conditional judgment and dynamic binding style method
  • How to dynamically bind style in Vue

<<:  Linux remote control windows system program (three methods)

>>:  A magical MySQL deadlock troubleshooting record

Recommend

Detailed steps for setting up a nexus server

1. The significance of building nexus service As ...

Vue routing to implement login interception

Table of contents 1. Overview 2. Routing Navigati...

How to build LNMP environment on Ubuntu 20.04

Simple description Since it was built with Centos...

3 ways to correctly modify the maximum number of connections in MySQL

We all know that after the MySQL database is inst...

Dynamic starry sky background implemented with CSS3

Result:Implementation Code html <link href=...

Detailed steps for installing Harbor, a private Docker repository

The installation of Harbor is pretty simple, but ...

js array entries() Get iteration method

Table of contents 1. Detailed syntax of entires()...

HTML uses form tags to implement the registration page example code

Case Description: - Use tables to achieve page ef...

MySQL 5.7.18 Archive compressed version installation tutorial

This article shares the specific method of instal...

Steps to introduce PWA into Vue project

Table of contents 1. Install dependencies 2. Conf...

Example test MySQL enum type

When developing a project, you will often encount...

Five solutions to cross-browser problems (summary)

Brief review: Browser compatibility issues are of...

Axios cancel request and avoid duplicate requests

Table of contents origin status quo Cancel reques...