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

今天主要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]">


华丽的分割线


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

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

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 4,989评论 0 29
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,125评论 0 6
  • 我的QQ头像~不会画手,不会画脚→_→,此外感觉没有好的上色工具最好不要上色。知道自己兴许又是三分钟热度,所以始终...
    好梦不遥远阅读 291评论 1 4