vue指令

1.v-model:双向数据绑定 用于表单元素

格式:v-model = " "
  <div class="demo">
          <p>{{mes}}</p>
          <input v-model="mes">
   </div>
   var app1 = new Vue({
           el: '.demo',
           data: {
           message: 'hello vue!'
       }
 })

2.v-on:指令添加一个事件监听器(绑定一个事件)

格式:v-on:事件名 = "函数名" (简写:@事件名=“函数名”)
<div class="demo">
 <p>{{msgs}}</p>
 <button v-on:click='btnb'>按钮</button>
</div>
<script src="vue/dist/vue.js"></script>
<script>
 var vm=new Vue({
     el:'.demo',
     data:{
         msg:'hello',
         flag:true
     },
     methods: {
         btnb: function () {
             this.msg = this.msgs
           if(this.flag){
                 this.msgs='hello vue'
                  this.flag=false
             }else{
               this.msgs='hello word'
               this.flag=true
           }
         }

    }
 })
</script>

3.v-bind:绑定属性

格式:v-bind:属性名=“函数名” (简写::属性名=“函数名”)
<div class="demo">
    <p v-on:click='btnp'><img v-bind:src="url" alt=""></p>
</div>
<script src="vue/dist/vue.js"></script>
<script>
    new Vue({
        el:'.demo',
        data:{
            url:'images/1.jpg',
            flag:true,
        },
        methods: {
            btnp: function () {
                this.url = this.flag
                if(this.flag){
                    this.url='images/2.jpg'
                    this.flag=false
                }else{
                    this.url='images/1.jpg'
                    this.flag=true
                }
            }

        }
    })
</script>

4.v-show 控制元素的隐藏和显示

格式:v-bind=" "
<div class="demo">
    <h1>{{msgs}}</h1>
    <h3 v-show='!alt'>{{msgs}}</h3>
</div>
<script src="vue/dist/vue.js"></script>
<script>
    new Vue({
        el:'.demo',
        data:{
            msgs:'oooo',
            alt:true
        }
    })
</script>

注:使用display:none隐藏

5.v-if、v-else、v-else-if

<div class="demo">
    <div v-if='num==0'>00000000000</div>
    <div v-else-if='num==1'>1111111111</div>
    <div v-else-if='num==2'>22222222</div>
    <div v-else='num==5'>555555555555</div>

</div>

<script src="vue/dist/vue.js"></script>
<script>
    new Vue({
        el:'.demo',
        data:{
            num:Math.floor(Math.random()*(5-0+1)+0)
        }
    })
</script>

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文 博客原文 大纲 1、什么是vue指令2、向指令中传入参数3、指令中带入修饰符4、指令的缩写5、常见的vue指...
    前端路上的小兵阅读 3,218评论 0 8
  • 页面展示 基本指令 v-text用于在页面中展示数据,可以简写为{{ }}的形式 {{msg}} <!--这两...
    羊烊羴阅读 5,359评论 0 0
  • 带有 v- 前缀的特殊属性 v-show 控制切换一个元素的显示和隐藏 语法:v-show = " 表达式 " 根...
    xlayzheng阅读 1,833评论 0 0
  • vue绑定属性的方法:通过指令v-bind,简写用冒号(:); 1. v-on用来绑定事件,简写@ 修饰符 sto...
    大仙爷阅读 1,768评论 0 0
  • 1. v-textv-text主要用来更新textContent,可以等同于JS的text属性。 这两者等价: 2...
    klmhly阅读 81,615评论 4 84