zoukankan      html  css  js  c++  java
  • Vuejs之v-bind介绍

    v-bind的介绍

    • 前面我们学习的指令主要作用是将值插入到我们模板的内容当中。
    • 但是,除了内容需要动态来决定外,某些属性我们也希望动态来绑定。
      • 比如动态绑定a元素的href属性
      • 比如动态绑定img元素的src属性
    • 这个时候,我们可以使用v-bind指定:
      • 作用:动态绑定属性
      • 缩写::
      • 预期:any(with argument) | object (whitout argument)
      • 参数:attrOrProp(option)

    v-bind基础

    • v-bind用于绑定一个多多个属性值,或者像一个组件创建props值(这个我们在学到组件时再介绍)
    • 在开发中,有哪些属性需要进行动态绑定呢?
      • 比如图片的链接(src)、网站的链接(href)、动态绑定一些类(class)、样式(style)等等
    • 比如通过Vue实例中的data绑定元素的src和href,代码如下
    <div id="app">
        <a v-bind:href="link">Vuejs官网</a>
        <img v-bind:src="logoUrl" alt=""/>
        
        <!-- 当然也可以通过语法糖“:”缩写v-bind -->
        <!-- <img :src="logoUrl" alt=""/> -->
    </div>
    
    <script src="/vue.js"></script>
    <script>
        let app = new Vue({
            el:"#app",
            data:{
                logoUrl:"http://vuejs.org/images/logo.png",
                link:"https://vuejs.org"
            }
        })
    </script>
    

    v-bind语法糖

    • v-bind有一个对应的语法糖,也就是简写方式
      • 在开发中,我们通常会使用语法糖的形式,因为这样更加简洁。
    • 简写方式如下:
    <div id="app">
        <a :href="link">Vuejs官网</a>
        <img :src="logoUrl" alt=""/>
    </div>
    

    v-bind 绑定class

    • 很多时候,我们希望动态的来切换class,比如:
      • 当数据为某个状态时,字体显示红色。
      • 当数据为另一个状态时,字体显示黑色。
    • 绑定class有两种方式:
      • 对象语法
      • 数组语法

    对象语法的含义是:class后面跟一个对象。

    对象语法有下面这些用法:

    用法一:直接通过{}绑定一个类
    <h2 :class="{active:isActive}">Hello world</h2>
    
    用法二:也可以通过判断,传入多个值
    <h2 :class="{active:isActive,line:isLine}">Hello world</2>  
    
    用法三:和普通的类同时存在,并不冲突
    注:如果isActive和IsLine都为true,那么会有title/active/line三个类
    <h2 class="title" :class="{active:isActive,line:isLine}">Hello world</h2>
    
    用法四:如果过于复杂,可以放在一个methods或者computed中
    注:classes是一个计算属性
    <h2 class="title" :class="classes">Hello world</h2>
    

    Demo:点击按钮切换字体颜色

    ...
    
    <style>
        .active{
            color:red;
        }    
    </style
    
    ...
    
    <div id="app">
    	<h1 v-bind:class="{active:isActive}">{{message}}</h1>
    	<button v-on:click="buttonClick()">颜色切换</button>
    </div>
    
    <script>
    	const vue = new Vue({
    		el: '#app',
    		data: {
    			message: 'hello world',
    			isActive:true
    		},
    		methods:{
    			buttonClick:function(){
    				this.isActive = !this.isActive;
    			}
    		}
    	})
    </script>
    

    数组语法的含义是:class后跟的是一个数组。

    数组语法有下面这些用法(数组语法一般用的比较少):

    用法一:直接通过[]绑定一个类
    <h2 :class="[active]">Hello world</h2>
    
    用法二:也可以传入多个值
    <h2 :class="[active,line]">Hello world</2>
    
    用法三:和普通的类同时存在,并不冲突
    注:会有title/active/line三个类
    <h2 class="title" :class="[active,line]">Hello world</h2>
    
    用法四:如果过于复杂,可以放在一个methods或者computed中
    注:classes是一个计算属性
    <h2 class="title" :class="classes">Hello world</h2>
    

    Demo:

    ... 
    
    <style>
    	.active{
    		color: red;
    	}
    	
    	.line{
    		font-size: 50px;
    	}
    	
    	.common{
    		color:green;
    	}
    </style>
    
    ...
    <div id="app">
        <!-- 如果加了单引号用的就是style中的指定class,如果没有单引号用的就是vue对象中的active变量 -->
        <!-- 注:这里,下面三个类将共存-->
    	<h2 class="common" :class="['active',line]">Hello world</h2>
    </div>
    
    <script>
    	const vue = new Vue({
    		el: '#app',
    		data: {
    			line:'line'
    		}
    	})
    </script>
    

    v-bind绑定style

    • 我们可以利用v-bind:style来绑定一些CSS内联样式
    • 在写CSS属性名的时候,比如font-size
      • 我们可以使用驼峰式(cameCase):fontSize
      • 或短横线分隔(kebab-case,记得用单引号括起来)'font-size'
    • 绑定class有两种方式:
      • 对象语法
      • 数组语法

    对象语法的含义就是style后面跟的是一个对象类型

    <!-- 对象key是CSS属性名称 -->
    <!-- 对象value是具体赋的值,值可以来自于data中的属性 -->
    :style="{coloc:currentColor,fontsize:fontsize+'px'}"
    

    数组语法的含义就是style后面跟的是一个数组类型

    <!-- 多个值以,分割即可-->
    <div v-bind:style="[baseStyles,overridingStyles]"></div>
    

    Demo:

    <div id="app">
    	<!-- 通过对象绑定style行内样式,值如果为字符串,那么将直接显示样式值 -->
    	<!-- <h1 :style="{color:'red'}">{{message}}</h1> -->
    
    	<!-- 通过变量来绑定行内样式表 -->
    	<!-- <h1 :style="{color:color}">{{message}}</h1> -->
    
    	<!-- 通过方法来绑定样式 -->
    	<!-- <h1 :style="getStyle()">{{message}}</h1> -->
    	
    	<!-- 通过数组来绑定样式 -->
    	<h1 :style="[common,bgColor]">{{message}}</h1>
    </div>
    
    <script type="text/javascript">
    	const vue = new Vue({
    		el: "#app",
    		data: {
    			message: "hello world",
    			color: 'red',
    			common:{color:'blue',fontSize:'10px'},
    			bgColor:{backgroundColor:'black'}
    		},
    		methods: {
    			getStyle: function() {
    				return {
    					color: this.color
    				};
    			}
    		}
    	})
    </script>
    
  • 相关阅读:
    奶牛编号(Cowids) [NOIP模拟]
    天天爱跑步 [NOIP2016]
    部落冲突
    狡猾的商人 [HNOI2005] [一题双解]
    最长公共子序列-LCS问题 (LCS与LIS在特殊条件下的转换) [洛谷1439]
    LeetCode 2. Add Two Numbers
    LeetCode 1. Two Sum
    LeetCode 91. Decode Ways
    LeetCode 516. Longest Palindromic Subsequence
    什么是马拉车算法(Manacher's Algorithm)?
  • 原文地址:https://www.cnblogs.com/insipid/p/13850085.html
Copyright © 2011-2022 走看看