从零开始学 Vue (二)—— 各种属性绑定

绑定title提示信息

除了上一章中的文本插值,我们也可以绑定DOM的其他属性:

<div id="root">
      <span v-bind:title="message">
           停留片刻查看动态消息
       </span>
</div>
                
<script src="../vue.js"></script>
<script>
      var app = new Vue({
           el: "#root",
           data: {
                 message: '现在时间为' + new Date().toLocaleString()
           }
       })
</script>

在浏览器打开此index.html文件,鼠标停留在文字区域,我们可以看到提示信息显示为现在时间为2017-09-07XXX 的提示信息,由此可以看出来,span中的title属性已经与app.message属性保持一致,上面出现的v-bind的属性在Vue中被称为指令,在Vue中,指令带有前缀v-,用来区分它们属于Vue中的属性。同样的我们也按F12呼出控制台,改变message的值,你会看到title的值也同步更新了。

循环与条件

我们来看下面的例子

<div id="root">
    <ul>
        <li v-for="item in items" v-if="item.show">
            {{item.msg}}
        </li>
    </ul>
</div>
var app = new Vue({
      el: "#root",
      data: {
         items: [
           {msg: 'Sherlock', show: true},
           {msg: 'Tina', show: false},
           {msg: 'Sherry', show: true},
           {msg: 'Aini', show: false},
           {msg: 'Nokia', show: true}
         ]
    }
})

在浏览器中它会显示以下效果:

  • Sherlock
  • Sherry
  • Nokia

上面我们看到了两个新的指令:v-forv-ifv-for指令可以展开数组数据,用来渲染一个项目列表,上面本应该展开输出以下效果:

  • Sherlock
  • Tina
  • Sherry
  • Aini
  • Nokia

这里为什么会少了TinaAini两项呢,这里就是另外一个指令v-if的效果了,控制元素的显示隐藏,由于TinaAini对应的show值为false,所以在展开的时候,这两项被隐藏了,我们也可以在控制台把Tina对应的show设置成true这时你会看到Tina会显示到正确的位置,而且,Vue也提供一个强大的过渡效果系统,可以在Vue插入、更新、删除元素时自动应用过渡效果

处理用户输入

最后我们来了解一下Vue是怎么处理用户的输入与交互的,这里用到一个新指令v-on,它可以绑定一个事件监听器,通过它调用Vue实例中我们定义的方法:

<div id="root">
    <p> {{ message }} </p>
    <button v-on:click="reverse"> 逆转消息 </button>
</div>

var app = new Vue({
    el: "#root",
    data: {
        message: "Hello World"
    },
    methods: {
        reverse: function() {
            this.message = this.message.split('').reverse().join('')
        }
    }
})

当我们在点击按钮的时候,触发点击事件,从而调用Vue实例的reverse方法,在方法中我们更新了应用的状态,但没有去操作DOM——所有的DOM操作都由Vue去处理,我们不用去处理这些琐事。

另外,这里还有一个指令也要一起说下,v-model指令,通过它我们能轻松实现表单输入和应用状态之间的双向绑定:

<div id="root">
    <p> {{ message }} </p>
    <input v-model="message">
</div>

var app = new Vue({
    el: "#root",
    data: {
        message: '请输入消息'
    }
})

当我们修改input元素的值时,p的值也会跟着改变。

结语

以上是Vue中最常见最基础的用法,希望自己先熟练基础之后再一步一步去学习Vue,以上代码也放到Github上了:
learnVue

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

推荐阅读更多精彩内容

  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,013评论 4 129
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,207评论 0 6
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,048评论 0 29
  • 1、今天心情有些烦躁 累 感恩ASKA幸福课程教会我零极限清理 对不起 请原谅 谢谢你 我爱你……
    刘葳阅读 154评论 0 0
  • 那个时候,邻里之间非常和睦, 相处一个院; 那个时候,邻里之间令人羡慕, 仅隔一堵墙; 那个时候,邻里之间串门来往...
    天马行空我也阅读 257评论 0 0