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 对象在创建时都要经过一系列的初始化过程。在这个过程中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>

效果如下:

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

点击按钮使数据更新后

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

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>

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

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>

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

 

给TA打赏
共{{data.count}}人
人已打赏
随笔日记

RxJS入门之函数响应式编程

2020-11-9 4:40:20

随笔日记

国资授权体制改革“不简单设时间表” 国资委正制定授权放权清单

2020-11-9 4:40:24

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索