v-model--双向数据绑定---:class控制样式--:style

Posted fdxjava

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了v-model--双向数据绑定---:class控制样式--:style相关的知识,希望对你有一定的参考价值。

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="./lib/vue-2.4.0.js"></script>
</head>

<body>
  <div id="app">
    <h4> msg </h4>

    <!-- v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定  -->
    <!-- <input type="text" v-bind:value="msg" style="width:100%;"> -->

    <!-- 使用  v-model 指令,可以实现 表单元素和 Model 中数据的双向数据绑定 -->
    <!-- 注意: v-model 只能运用在 表单元素中 -->
    <!-- input(radio, text, address, email....)   select    checkbox   textarea   -->
    <input type="text" style="width:100%;" v-model="msg">
  </div>

  <script>
    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue(
      el: #app,
      data: 
        msg: 大家都是好学生,爱敲代码,爱学习,爱思考,简直是完美,没瑕疵!
      ,
      methods: 
      
    );
  </script>
</body>

</html>
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="./lib/vue-2.4.0.js"></script>
  <style>
    .red 
      color: red;
    

    .thin 
      font-weight: 200;
    

    .italic 
      font-style: italic;
    

    .active 
      letter-spacing: 0.5em;
    
  </style>
</head>

<body>
  <div id="app">
    <!-- <h1 class="red thin">这是一个很大很大的H1,大到你无法想象!!!</h1> -->

    <!-- 第一种使用方式,直接传递一个数组,注意: 这里的 class 需要使用  v-bind 做数据绑定 -->
    <!-- <h1 :class="[‘thin‘, ‘italic‘]">这是一个很大很大的H1,大到你无法想象!!!</h1> -->

    <!-- 在数组中使用三元表达式 -->
    <!-- <h1 :class="[‘thin‘, ‘italic‘, flag?‘active‘:‘‘]">这是一个很大很大的H1,大到你无法想象!!!</h1> -->

    <!-- 在数组中使用 对象来代替三元表达式,提高代码的可读性 -->
    <!-- <h1 :class="[‘thin‘, ‘italic‘, ‘active‘:flag ]">这是一个很大很大的H1,大到你无法想象!!!</h1> -->

    <!-- 在为 class 使用 v-bind 绑定 对象的时候,对象的属性是类名,由于 对象的属性可带引号,也可不带引号,所以 这里我没写引号;  属性的值 是一个标识符 -->
    <h1 :class="classObj">这是一个很大很大的H1,大到你无法想象!!!</h1>


  </div>

  <script>
    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue(
      el: #app,
      data: 
        flag: true,
        classObj:  red: true, thin: true, italic: false, active: false 
      ,
      methods: 
    );
  </script>
</body>

</html>
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="./lib/vue-2.4.0.js"></script>
</head>

<body>
  <div id="app">
    <!-- 对象就是无序键值对的集合 -->
    <!-- <h1 :style="styleObj1">这是一个h1</h1> -->

    <h1 :style="[ styleObj1, styleObj2 ]">这是一个h1</h1>
  </div>

  <script>
    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue(
      el: #app,
      data: 
        styleObj1:  color: red, font-weight: 200 ,
        styleObj2:  font-style: italic 
      ,
      methods: 
    );
  </script>
</body>

</html>

 

以上是关于v-model--双向数据绑定---:class控制样式--:style的主要内容,如果未能解决你的问题,请参考以下文章

v-mode 双向数据绑定

vue3自定义组件使用v-model实现双向数据绑定

Vue—数据的双向绑定v-model

第四 表单指令 v-model 双向数据绑定

v-model双向绑定

vue中v-model 数据双向绑定