• Vue基本使用---对象提供的属性功能


    一 过滤器

    过滤器就是vue允许开发者自定义的文本格式化函数,

    可以使用在两个地方:输出内容和操作数据中。

    1.1 定义过滤器的两种方式

    1.1.1 使用Vue.filter()进行全局定义

    Vue.filter("RMB1", function(v){
          //就是来格式化(处理)v这个数据的
          if(v==0){
                return v
          }
          return v+"元"
    })

    1.1.2 在Vue对象中通过filters属性类定义

    var vm = new Vue({
      el:"#app",
      data:{},
      filters:{
        RMB2:function(value){
          if(value==''){
            return;
          }else{
              return '¥ '+value;
          }
        }
        }
    });

     1.2 计算和监听属性

    监听属性,可以帮助我们侦听data中某个数据的变化,从而做相应的自定义操作。

    监听属性时一个对象,它的键时要监听的对象或者变量,值是一个函数,当监听的data数据发送变化时,会自定义执行对应的函数,这个函数在被调用时,vue会传入两个形参,第一个是变化前的数据值,第二个是变化后的数据值。

    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.js"></script>
    </head>
    <body>
    <div id="app">
        <p>{{ num }}</p>
        <button @click="num++">按钮</button>
    </div>
    <script>
        let vm = new Vue({
            el: "#app",
            data: {num: 23,},
            watch: {
                //num发生变化的时候,要执行的代码,num必须是data中的键
                num: function (newval, oldval) {
                    console.log("num已经发生变化了!", this.num)
                },
            }
        })
    </script>
    </body>
    </html>

    二  Vue 对象的生命周期

    每个vue 对象在创建时都要经过一系列的初始化过程。在这个过程中vue.js会自动运行一些叫做生命周期的钩子函数,我们可以使用这些函数,在对象创建的不同阶段加上我们需要的代码,实现特定的功能。

    2.1 了解数据生成、加载、更新的过程

    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>title</title>
        <script src="js/vue.js"></script>
    </head>
    <body>
    <div id="app">
        <p>{{ num }}</p>
        <button @click="num++"> 按钮</button>
    </div>
    <script>
        let vm = new Vue({
            el: "#app",
            data: {num: 0},
            beforeCreate: function () {
                console.log("beforeCreate,vm对象尚未创建,num=" + this.num);
                this.name = "zhangsan"; //此时没有this对象,设置name是无效的
            },
            created: function () {
                console.log("created,vm对象创建完成,设置好了要控制的元素范围,num=" + this.num);  // 0
                this.num = 20;
            },
            beforeMount: function () {
                // this.$el 就是我们上面的el属性了,$el表示当前vue.js所控制的元素#app
                console.log(this.$el.innerHTML);
                console.log("beforeMount,vm 对象尚未把data数据显示到页面中,num=" + this.num);
            },
            mounted: function () {
                console.log(this.$el.innerHTML);
                console.log("mounted,vm对象已经把data数据显示到页面中,num=" + this.num);
            },
            beforeUpdate: function () {
                console.log(this.$el.innerHTML);
                console.log("beforeUpdate,vm对象尚未把更新后的data数据显示到页面中,num=" + this.num);
            },
            updated: function () {
                console.log(this.$el.innerHTML);
                console.log("updated,vm对象已经把更新后的data数据显示到页面中,num=" + this.num);
            },
        })
    </script>
    </body>
    </html>

    效果如下:

    点击按钮使数据更新后

    2.2 总结

    在vue使用的过程中,如果要初始化操作,把初始化操作的代码放在 mounted 中执行。
    mounted阶段就是在vm对象已经把data数据实现到页面以后。

    一般页面初始化使用。例如,用户访问页面加载成功以后,就要执行的ajax请求。

    另一个就是created,这个阶段就是在 vue对象创建以后,把ajax请求后端数据的代码放进 created

    三 阻止事件冒泡和刷新页面

    3.1 阻止事件冒泡

    通过 设置@click.stop来阻止事件冒泡

    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.js"></script>
        <style>
            .box1 {
                width: 200px;
                height: 200px;
                background: #ccc;
            }
    
            .box2 {
                width: 100px;
                height: 100px;
                background: pink;
            }
        </style>
    </head>
    <body>
    <div id="app">
        <div class="box1" @click="func1">
            <!-- @click.stop来阻止事件冒泡 -->
            <div class="box2" @click.stop.prevent="func2"></div>
        </div>
    </div>
    <script>
        let vm = new Vue({
            el: "#app",
            data: {},
            methods: {
                func1: function () {
                    console.log("box1")
                },
                func2: function () {
                    console.log("box2")
                }
            }
        })
    </script>
    </body>
    </html>

    3.2  阻止表单提交和页面刷新

    通过设置 @click.prevent来阻止表单提交

    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.js"></script>
    </head>
    <body>
    <div id="app">
        <form action="">
            <input type="text">
            <input type="submit">
            <!-- @click.prevent来阻止表单提交 -->
            <input type="submit" value="提交02" @click.prevent="func3">
        </form>
    </div>
    <script>
        let vm = new Vue({
            el: "#app",
            data: {},
            methods: {
                func3: function () {
                    console.log("页面不刷新时执行点击提交的函数")
                },
            }
        })
    </script>
    </body>
    </html>

  • 相关阅读:
    js 实现自增长
    常用的js脚本验证
    Jquery 收集
    Jquery 常用操作搜集
    Jquery 点击绑定行 弹出详细页面
    Jquery 了解
    Html 标尺
    Editor Guidelines
    程序员需要做到
    jS 回车事件
  • 原文地址:https://www.cnblogs.com/Sunzz/p/10785795.html
Copyright © 2020-2023  润新知