适合初学者的Vue-1.0教程(二)

在学习了教程(yi),之后大家对data,method,v-for,v-on相信都有所了解了
现在进一步介绍Vue
v-on:因为经常被使用,所以它有个简写即@

    <div id="box">
        <input type="button" value="按钮1" v-on:click="AlertMsg1()">
        <input type="button" value="按钮2" @click="AlertMsg2()">
    </div>
    <script src="../lib/vue.js"></script>
    <script>
        window.onload = function () {
            var vm = new Vue({
                el:"#box",
                data:{},
                methods:{
                    AlertMsg1:function(){
                        alert(1)
                    },
                    AlertMsg2:function(){
                        alert(2)
                    }
                }
            })
        }
    </script>
image.png

按钮1和按钮2都会弹出数字,说明指令v-on:等价于@

接上文的例子,讲一下事件冒泡

    <div id="box">
        <div @click="AlertMsg2()">
            <input type="button" value="按钮1" v-on:click="AlertMsg1()">
        </div>
    </div>
image.png
image.png

点击之后,先弹出1,再弹出2,说明里面元素的事件先触发,它的父元素后触发
为了阻止冒泡,我们得做点什么

<input type="button" value="按钮1" v-on:click="AlertMsg1($event)">
AlertMsg1: function (e) {
                        alert(1)
                        e.cancelBubble=true
                    }

修改了这两段代码之后,就不会冒泡了
但是,仍然很麻烦,能不能再简单一点呢?

            <input type="button" value="按钮1" v-on:click.stop="AlertMsg1()">
AlertMsg1: function (e) {
                        alert(1)
                    }

那现在只要在事件后面加上“.stop”就可以阻止冒泡了!
除了阻止冒泡,对于事件我们还经常在表单上,阻止默认行为,改怎么做呢?

//传统的做法
e.preventDefault
//Vue的做法
        <form action="/" id="formCs" @submit.prevent="AlertMsg1()"> 
            <input type="submit" >
        </form>

这样就阻止了默认行为,只要加“.prevent”就可以了
还有常用的键盘事件

    <div id="box">
        <input type="text" @keydown="alert1($event)">
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {},
                methods: {
                    alert1: function (e) {
                        alert(e.keyCode)
                    }
                }
            })
    </script>
image.png

在输入框,每次按下键盘的按键后,会弹出相应的码号
常用的键盘事件除了keydown还有keyup
有的时候我们希望只在相应的按键触发处理函数,则必须在函数里做一个判断

if(e.keyCode===xx){}

现有有更简单的方式

<input type="text" @keydown.65="alert1($event)">

在键盘事件后面加上“.键的码号”,“a”的码号是65,所以只有输入a时才调用处理函数
对于码号,比较常用的也做了处理,
比如上、下、左、右四个方向键分别用.up、.down、.left、right,还有回车键.enter、.Alt等

    <div id="box">
        ![]({{url}})
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    url:'https://www.baidu.com/img/bd_logo1.png'
                },
                methods: {
                }
            })
    </script>

会报错,没有效果

        ![](url)

使用v-bind:指令绑定属性

![](url)

“v-bind:”指令的简化语法“:”
如果绑定class属性Vue给出了更多语法

    <style>
    .blue{
        color:blue;
    }
    </style>
    <div id="box">
        <h4 :class="blue">Vue属性绑定</h4>
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    blue:'blue'
                },
                methods: {
                }
            })
    </script>
image.png

如果添加多个class

    <style>
    .blue{
        color:blue;
    }
    .yellow{
        background:yellow;
    }
    </style>
    <div id="box">
        <h4 :class="[blue,yellow]">Vue属性绑定</h4>
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    blue:'blue',
                    yellow:'yellow'
                },
                methods: {
                }
            })
    </script>
image.png

如果class的值想让它在需要的时候出现,不需要时隐藏,该怎么办

    <style>
    .blue{
        color:blue;
    }
    </style>
    <div id="box">
        <h4 :class="{blue:true}">Vue属性绑定</h4>
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    blue:'blue'
                },
                methods: {
                }
            })
    </script>
image.png
        <h4 :class="{blue:false}">Vue属性绑定</h4>

当对象内blue的值为false时,则class隐藏

image.png

用chrome检查元素,就会发现class的值没有了
一般我们这样用这个特性

    <style>
    .blue{
        color:blue;
    }
    .yellow{
        background:yellow
    }
    </style>
    <div id="box">
        <h4 :class="json">Vue属性绑定</h4>
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    json:{
                        blue:true,
                        yellow:false
                    }
                },
                methods: {
                }
            })
    </script>
image.png

浏览器检查元素Elements会显示


image.png

因此style也是如此

    <div id="box">
        <h4 :style="[blue,yellow]">Vue属性绑定</h4>
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    blue:{color:'blue'},
                    yellow:{backgroundColor:'yellow'}
                },
                methods: {
                }
            })
    </script>
image.png

但是复合样式,必须采用驼峰命名法
接下来,会介绍Vue的模板

    <div id="box">
        <input type="text" v-model="msg">
        <br>
        {{msg}}
    </div>
    <script>
            new Vue({
                el: "#box",
                data: {
                    msg:'welcome you'
                 },
                methods: {
                }
            })
    </script>
image.png
image.png

v-model指令,在输入框的数据会更新模板变化,msg被更新了
如果只绑定一次,怎么办

    <div id="box">
        <input type="text" v-model="msg">
        <br>
        <span>{{msg}}</span>
        <br>
        <span v-once>{{msg}}</span>
    </div>
image.png
image.png

data对象msg属性的值更新时,插值处的{{msg}}的值会更新
但使用v-once指令后,则只会在刚开始更新,后来数据更新时,则不会跟着更新
如果data对象的msg的值是html

    <div id="box">
        <input type="text" v-model="msg">
        <br>
        <span>{{msg}}</span>
        <br>
        <span v-html="msg"></span>
    </div>
image.png
<span>{{'msg'}}</span>
image.png

使用引号包裹之后,模板就无效了

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

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,046评论 0 29
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,002评论 4 129
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,834评论 25 707
  • 我迷失了一段记忆, 记忆里是我不懂的虚无。 我把所有的猜想加铸, 仍是沧海桑田的茫茫。 若有若无的片段, 纠葛不清...
    糜情阅读 194评论 0 1
  • 今天周天,没有安排任何的事项,放松下来陪伴家人和自己。 以前自己想做一件事情的时候会先产生很多想法:这件事有没有意...
    雅婷1225阅读 232评论 0 0