美文网首页前端攻城狮Web前端之路让前端飞
Vue2.0系列(二、vue基本指令)

Vue2.0系列(二、vue基本指令)

作者: 范小饭_ | 来源:发表于2017-07-02 21:25 被阅读579次

今天主要vue的使用
v-if,v-for,v-model,数据双向绑定,处理表单和选框,class与style的常用绑定,v-on等等。

一,数据绑定

1,vue允许采用简洁的模板语法声明式的将数据渲染进DOM

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">{{msg}}</div>
    <script type="text/javascript">
        new Vue({
            el:'#app',
            data:{
                msg:'hello!'
            }           
        })
    </script>
</body>
</html>

页面效果


01.jpg

2,通过数据绑定事件来更改数据从而改变视图

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">{{msg}}
    <button :title="msg" @click="changeText">点击</button>
    </div>
    <script type="text/javascript">
        new Vue({
            el:'#app',
            data:{
                msg:'点我有惊喜'
            },
            methods:{
                changeText:function(){
                    this.msg = "哈哈,上当了吧~"
                }
            }           
        })
    </script>
</body>
</html>

页面效果:


GIF.gif

二,条件与循环 v-if

v-if指令去控制切换一个元素的显示隐藏

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <span v-if="seen">
            哈哈,你看不到我~
        </span>
    </div>
    <script type="text/javascript">
        new Vue({
            el:'#app',
            data:{
                seen:false
            }
        })
    </script>
</body>
</html>

此时 seen=false,页面上是没有显示任何元素的,但是如果seen=true,那么我们在页面上是可以看到元素内容的。
这个例子演示了我们不仅可以绑定DOM文本到数据,也可以绑定DOM结构到数据。而且,Vue也提供了一个强大的过渡效果系统,可以在Vue插入/更新/删除元素时自动应用过度效果,这个方面,小伙伴可以选择自行进阶学习。

v-for渲染一个项目列表

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <div v-for="item in lists">{{item.text}}</div>
    </div>
    <script type="text/javascript">
        new Vue({
            el:'#app',
            data:{
                lists:[
                    {text:'周杰伦'},
                    {text:'蔡依林'},
                    {text:'林俊杰'}
                ]
            }
        })
    </script>
</body>
</html>

页面效果


03.jpg

三,双向数据绑定

Vue还提供了v-model指令,他能轻松实现表单输入和应用状态之间的双向绑定。

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <h1>{{message}}</h1>
        <input type="text" v-model="message" name="">
    </div>
    <script type="text/javascript">
        new Vue({
            el:'#app',
            data:{
                message:'hello'
            }
        })
    </script>
</body>
</html>

页面效果


GIF.gif

处理复选框(一)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <input type="checkbox" id="checkbox" v-model="checked">
        <label for="checkbox">{{ checked }}</label>
    </div>

    <script type="text/javascript">
        var app = new Vue({
          el: '#app',
          data: {
            checked: false
          },
        })
    </script>
</body>
</html>

案例效果


GIF.gif

处理复选框(二)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <input type="checkbox" id="food" value="美食" v-model="checked">
            <label for="jack">美食</label>
        <input type="checkbox" id="view" value="美景" v-model="checked">
            <label for="john">美景</label>
        <input type="checkbox" id="beau" value="美人" v-model="checked">
            <label for="mike">美人</label>
        <br>
        <span>Checked: {{ checked }}</span>
    </div>

    <script type="text/javascript">
        var app = new Vue({
          el: '#app',
          data: {
            checked: []
          },
        })
    </script>
</body>
</html>

案例效果

GIF.gif

单选按钮

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <input type="radio" id="one" value="江山" v-model="picked">
        <label for="one">江山</label>
        <br>
        <input type="radio" id="two" value="美人" v-model="picked">
        <label for="two">美人</label>
        <br>
        <span>Picked: {{ picked }}</span>
    </div>

    <script type="text/javascript">
        var app = new Vue({
          el: '#app',
          data: {
            picked:''
          },
        })
    </script>
</body>
</html>

案例效果

GIF.gif

下拉选框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <select v-model="selected">
            <option disabled value="">请选择</option>
            <option>周杰伦</option>
            <option>蔡依林</option>
            <option>张靓颖</option>
        </select>
        <span>Selected: {{ selected }}</span>
    </div>

    <script type="text/javascript">
        var app = new Vue({
          el: '#app',
          data: {
            selected:null
          },
        })
    </script>
</body>
</html>

如果 v-model 表达初始的值不匹配任何的选项,<select> 元素就会以”未选中”的状态渲染。在 iOS 中,这会使用户无法选择第一个选项,因为这样的情况下,iOS 不会引发 change 事件。因此,像以上提供 disabled 选项是建议的做法。
案例效果

GIF.gif

多项列表(绑定到一个数组)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <select v-model="selected" multiple style="width: 50px">
            <option>A</option>
            <option>B</option>
            <option>C</option>
        </select>
        <br>
        <span>Selected: {{ selected }}</span>
    </div>
    <script type="text/javascript">
        new Vue({
          el: '#app',
          data: {
            selected: []
          }
        })
    </script>
    
</body>
</html>

案例效果

GIF.gif

动态选项

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <select v-model="selected">
          <option v-for="option in options" v-bind:value="option.value">
            {{ option.text }}
          </option>
        </select>
        <span>Selected: {{ selected }}</span>
    </div>
    <script type="text/javascript">
        new Vue({
          el: '#app',
          data: {
            selected: 'A',
            options: [
              { text: '《七里香》', value: '周杰伦' },
              { text: '《布拉格广场》', value: '蔡依林' },
              { text: '《演员》', value: '薛之谦' }
            ]
          }
        })
    </script>
    
</body>
</html>

案例效果

GIF.gif

v-on
为了让用户和你的应用进行互动,我们可以用v-on指令绑定一个时间监听器,通过它调用我们Vue实例中定义的方法:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
      <p>{{ message }}</p>
      <button v-on:click="reverseMessage">逆转消息</button>
    </div>
    <script type="text/javascript">
        var app = new Vue({
          el: '#app',
          data: {
            message: '时间是一种解药,更是我现在服下的毒药。'
          },
          methods: {
            reverseMessage: function () {
              this.message = this.message.split('').reverse().join('')
            }
          }
        })
    </script>
</body>
</html>

案例效果


GIF.gif

关于修饰符

.number
如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值:
<input v-model.number="age" type="number">

.trim
如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入:
<input v-model.trim="msg">

.lazy
在默认情况下,v-model在input事件中同步输入框的值与数据 (除了 上述IME 部分),但你可以添加一个修饰符lazy,从而转变为在change事件中同步:

<!-- 在 "change" 而不是 "input" 事件中更新 -->
<input v-model.lazy="msg" >

四,class与style的绑定

对象语法
我们可以传给 v-bind:class 一个对象,来动态的切换class。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.danger{color: green;}
</style>
<body >
    <div class="static"
     v-bind:class="{ active: isActive, 'danger': hasError }" id="app">
        时间是一种解药,更是我现在正服下的毒药。。。
     </div>

    <script type="text/javascript">
        new Vue({
                el:'#app',
                data: {
                    isActive: true,
                    hasError: false
                }
            })
    </script>
</body>
    
</html>

案例效果


04.jpg

当isActive或者hasError变化时,class列表经相应的更新。

根据对象的计算属性,绑定相应的样式。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.text-danger{color: green;}
</style>
<body >
    <div v-bind:class="classObject" id="app">
        时间是一种解药,更是我现在正服下的毒药。。。
    </div>
    <script type="text/javascript">
        new Vue({
                el:'#app',
                data: {
                  isActive: true,
                  error: false
                },
                computed: {
                  classObject: function () {
                    return {
                      active: this.isActive && !this.error
                    }
                  }
                }
            })
    </script>
</body>
    
</html>

此案例与上述案例效果同

数组语法
可以把一个数组传给v-bind:class,以应用一个class列表

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.danger{background: green;}
</style>
<body >
    <div v-bind:class="[activeClass, errorClass]" id="app">
        时间是一种解药,更是我现在正服下的毒药。。。
    </div>
    <script type="text/javascript">
        new Vue({
                el:'#app',
                data: {
                    activeClass: 'active',
                    errorClass: 'danger'
                }
            })
    </script>
</body>
    
</html>
05.jpg

当然你也可以根据条件切换列表中的class,可以使用三元表达式,这个也是很常用的
<div v-bind:class="[isActive ? activeClass : '', errorClass]">


华丽的分割线


我是乐观的范小饭,喜欢就点赞,真爱就打赏,地铁口买煎饼果子的时候,可以奢侈的加个蛋~

相关文章

网友评论

    本文标题:Vue2.0系列(二、vue基本指令)

    本文链接:https://www.haomeiwen.com/subject/zpurfxtx.html