vuejs指令总结

vuejs指令总结

一句话概括:数据决定决定显示

简介:Vue.js的指令是以v-开头的,它们作用于HTML元素,会为绑定的目标元素添加一些特殊的行为,可以将指令看作特殊的HTML特性(attribute)。

特别提示:

1.{{这里必须是一个表达式}}

  1. v-指令 这种格式,一旦使用了指令,虽然我们写的值看起来是字符串,因为我们使用"值",但这个值已经是javascript了。

  2. v-text

    v-text可以用于替换插值表达式,如果有v-text,那么插值不起使用

    <div v-text="这里是javascript,而不是普通的字符">{{msg}}</div>
    <div v-text="'这里v-text的内容'">{{msg}}</div> //前者会生效,后者被替代
    <div v-text="msg"></div> //这样可显示msg的内容
    
  3. v-html

    如果是富文本编辑器的内容,直接渲染的话,是被转义过的,那么html标签就会直接被渲染到页面

    //错误示范
    <div id="root"> 
     <div>{{content}}</div>
    </div>
    <!-- 如果要输出正确的不带html标签转义的内容,就需要使用v-html指令 -->
    
    //正确用法
    <div v-html="content"> 
    </div>
    
    <script>
      const app = new Vue({
        el: "#root",
        data: {
          msg: 'Hello 1901',
          content: '<p>这是后台<b>富文本编辑器</b>生成的<span style="font-size: 18px;">内容</span></p>'
        }
      })
    </script>
    

常见内置指令:

  • v-if指令

  • v-show指令

  • v-else指令

  • v-for指令

  • v-bind指令

  • v-on指令

v-if指令

v-if是条件渲染指令,它根据表达式的真假来删除和插入元素

基本语法:
v-if="expression(表达式)"
expression是一个返回布尔值的表达式,表达式可以是一个布尔属性,也可以是一个返回布尔的运算式。

<div id="app">
            <div v-if="isCompleted">已完成</div>
            <div v-if="age>=20">age:{{age}}</div>
        </div>
        
var vm = new Vue({
            el: '#app',
            data: {
                age:25,
                isCompleted: true
            }
        })

v-else指令

v-else指令与v-if或者v-show同时使用,v-if条件不成立则会显示v-else内容

<div id="app">
            <div v-if="isMale">男士</div>
            <div v-else>女士</div>
        </div>

var vm = new Vue({
    el: '#app',
    data: {
        isMale:true
    }
})

v-for指令

v-for指令基于一个数组渲染一个列表,它和JavaScript的遍历语法相似
v-for="item in list"
list是一个数组,item是当前遍历的数组元素
v-for="(item,index) in list"其中index是当前循环的索引,下标从0开始

<div id="root">
    <div>{{msg}}</div>
    <ul>
      <li v-for="item in list">
        <span>{{item.id}}</span>
        <span>{{item.title}}</span>
        <span>{{item.isCompleted ? '已完成' : '未完成'}}</span>
        <span v-if="item.isCompleted === true" style="color: #090">已完成</span>
        <i v-else style="color: #F00">未完成</i>
      </li>
    </ul>
  </div>

<script>
    const app = new Vue({
      el: "#root",
      data: {
        msg: 'Hello 1901',
        list: [{
          id: 1,
          title: '打豆豆',
          isCompleted: true
        }, {
          id: 2,
          title: '写程序',
          isCompleted: false
        }, {
          id: 3,
          title: '吃饭',
          isCompleted: false
        }]
      }
    })
  </script>

v-bind指令

v-bind:属性 用于动态绑定元素的属性 ,可简写为 :属性

<div id="root">
    <ul>
      <!-- v-bind:属性 用于动态绑定元素的属性 -->
      <li v-for="item in list" v-bind:key="item.id">
        <!-- v-bind:属性可以直接简写为:属性 -->
        <span>{{item.id}}</span>.<span :title="item.title">{{item.title}}</span>
      </li>
    </ul>
    
  </div>

<script>
    const app = new Vue({
      el: "#root",
      data: {
        msg: 'Hello 1901',
        list: [{
          id: 1,
          title: '打豆豆'
        }
        }]
      }
    })
  </script>

v-on 指令

v-on用于监听DOM事件,用法和v-bind类似,例如给button添加点击事件
<button v-on:click="show">
同样,和v-bind一样,v-on也可以使用简写,用@符号代替,修改代码:
<button @click="show">

我们来看个例子:

img
<div id="root">
    <!-- v-on:事件名 用于绑定一个事件,这个事件里可以直接操作data里的数据 -->
    <button v-on:click="isModalShow = !isModalShow">隐藏/显示弹窗</button>
    <!-- v-on:事件名可以缩写为 @事件名 -->
    <button @click="isModalShow = !isModalShow">隐藏/显示弹窗</button>
    <!-- 要想写成一个方法 -->
    <button @click="toggleModalShow">隐藏/显示弹窗</button>

    <div v-show="isModalShow === true">这是一个弹窗</div>
  </div>
  <script src="./vue.js"></script>
  <script>
    const app = new Vue({
      el: "#root",
      data: {
        isModalShow: true
      },
      methods: {
        // vue里的方法必须写在methods里面
        toggleModalShow() {
          this.isModalShow = !this.isModalShow
        }
      }
    })
  </script>

v-show指令

v-show和v-if区别。
v-show不管条件是否成立,都会渲染html,而v-if只有条件成立才会渲染

  • v-if 直接是移除dom节点或者插入v-show是通过改变style的css样式,即display

    v-show对于需要频繁切换显示隐藏的节点特别适用,特别是弹窗,手机注册,邮箱注册的两个tab的切换

  <div id="root">
   
    <div v-if="isModalShow === true">这是一个弹窗</div>
    <div v-show="isModalShow === true">这是另一个弹窗</div>
  </div>

  <script src="./vue.js"></script>
  <script>
    const app = new Vue({
      el: "#root",
      data: {
        isModalShow: true
      }
    })
  </script>
                • 待完善
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,044评论 0 29
  • 生成vue的实例 var vm=new vue({//这里是选项 他可以包含数据、模板、挂载元素、方法、生命周期钩...
    麦子_FE阅读 997评论 1 11
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,198评论 0 6
  • Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on Vue.js的指...
    干净_79db阅读 773评论 0 0
  • vue概述 在官方文档中,有一句话对Vue的定位说的很明确:Vue.js 的核心是一个允许采用简洁的模板语法来声明...
    li4065阅读 7,185评论 0 25