美文网首页前端攻城狮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