zoukankan      html  css  js  c++  java
  • Vue2.0 【第三季】第3节 Methods Option 方法选项

    Vue2.0 【第三季】第3节 Methods Option 方法选项


    第3节 Methods Option 方法选项

    在以前的学习中,已经大量的使用了构造器里的methods选项,但是并没有仔细和系统的讲解过,这节课把methods这个选项涉及的东西都讲一讲。

    我们还是复习一下最简单的使用方法,一个数字,每点击一下按钮加1。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <script type="text/javascript" src="../assets/js/vue.js"></script>
        <title>methods Option</title>
    </head>
    <body>
        <h1>methods Option</h1>
        <hr>
        <div id="app">
            {{ a }}
            <p><button @click="add">add</button></p>
        </div>
    
        <script type="text/javascript">
            var app=new Vue({
                el:'#app',
                data:{
                    a:1
                },
                methods:{
                    add:function(){
                        this.a++
                    }
                }
            })
        </script>
    </body>
    </html>
    

    一、methods中参数的传递

    使用方法和正常的javascript传递参数的方法一样,分为两步:

    • 在methods的方法中进行声明,比如我们给add方法加上一个num参数,就要写出add:function(num){}
    • 调用方法时直接传递,比如我们要传递2这个参数,我们在button上就直接可以写<button @click=”add(2)”></button>

    现在知道了加参数的方法,看一段完整的代码,代码中给add添加了num参数,并在按钮上调用传递了。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <script type="text/javascript" src="../assets/js/vue.js"></script>
        <title>methods Option</title>
    </head>
    <body>
        <h1>methods Option</h1>
        <hr>
        <div id="app">
            {{ a }}
            <p><button @click="add(5)">add</button></p>
        </div>
    
        <script type="text/javascript">
            var app=new Vue({
                el:'#app',
                data:{
                    a:1
                },
                methods:{
                    add:function(num){
                        if(num!=''){
                            this.a+=num;
                        }else{
                            this.a++;
                        }
                    }
                }
            })
        </script>
    </body>
    </html>
    

    浏览器效果:

    这时,再点击按钮是每次加5个数字。

    二、methods中的$event参数

    传递的$event参数都是关于你点击鼠标的一些事件和属性。我们先看看传递的方法。

    传递:

    <button @click=”add(5,$event)”>add</button> 
    

    我们这时候可以打印一下,看看event到底是个怎样的对象。你会发现,它包含了大部分鼠标事件的属性。

    三、native给组件绑定构造器里的原生事件

    在实际开发中经常需要把某个按钮封装成组件,然后反复使用,如何让组件调用构造器里的方法,而不是组件里的方法。就需要用到我们的.native修饰器了。

    现在我们把我们的add按钮封装成组件:

    声明btn对象:

    var btn={
        template:`<button>组件Add</button>`     
    }
    

    在构造器里声明:

    components:{
        "btn":btn
     }
    

    用.native修饰器来调用构造器里的add方法

    <p><btn @click.native="add(3)"></btn></p>
    

    全部代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <script type="text/javascript" src="../assets/js/vue.js"></script>
        <title>methods Option</title>
    </head>
    <body>
        <h1>methods Option</h1>
        <hr>
        <div id="app">
            {{ a }}
            <p><button @click="add(5)">add</button></p>
            <p><btn @click.native="add(3)"></btn></p>
        </div>
    
        <script type="text/javascript">
            var btn={
                template:`<button>组件Add</button>`     
            }
    
            var app=new Vue({
                el:'#app',
                data:{
                    a:1
                },
                components:{
                    "btn":btn
                },
                methods:{
                    add:function(num){
                        if(num!=''){
                            this.a+=num;
                        }else{
                            this.a++;
                        }
                    }
                }
            })
        </script>
    </body>
    </html>
    

    浏览器效果:

    这种方法很常用,必须掌握。

    四、作用域外部调用构造器里的方法

    这种不经常使用,如果你出现了这种情况,说明你的代码组织不够好。

    <button onclick="app.add(4)" >外部调用构造器里的方法</button>
    

    浏览器效果:

    Keep moving on!
  • 相关阅读:
    高位前缀和,求他的子集的和https://ac.nowcoder.com/acm/contest/4784/A
    Codeforces Global Round 7 E. Bombs
    高精度,乘法加法
    2018-ICPC-焦作区预赛
    状压dp,区间dp,矩阵快速幂
    树状数组,适用于单点修改,区间查询
    离散化函数
    带修莫队模版
    树链剖分 https://www.luogu.com.cn/problem/P3384
    HDU 1016 Prime Ring Problem【DFS】
  • 原文地址:https://www.cnblogs.com/Elva3zora/p/12505907.html
Copyright © 2011-2022 走看看