vue v-html 对象属性,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会传入两个形参,第一个是变化前的数据值,第二个是变化后的数据值。

Title

{{ num }}

按钮

let vm = new Vue({

el: "#app",

data: {num: 23,},

watch: {

//num发生变化的时候,要执行的代码,num必须是data中的键

num: function (newval, oldval) {

console.log("num已经发生变化了!", this.num)

},

}

})

028a4bcf3dad68f4b4b9e28b3878755f.png

二  Vue 对象的生命周期

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

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

title

{{ num }}

按钮

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);

},

})

效果如下:

a6c963d200acc45df9c167292dffe1b2.png

点击按钮使数据更新后

925bba20c0bdc31ba81ed8d6369bfde8.png

2.2 总结

在vue使用的过程中,如果要初始化操作,把初始化操作的代码放在 mounted 中执行。

mounted阶段就是在vm对象已经把data数据实现到页面以后。

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

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

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

3.1 阻止事件冒泡

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

Title

.box1 {

width: 200px;

height: 200px;

background: #ccc;

}

.box2 {

width: 100px;

height: 100px;

background: pink;

}

let vm = new Vue({

el: "#app",

data: {},

methods: {

func1: function () {

console.log("box1")

},

func2: function () {

console.log("box2")

}

}

})

1a8d7e8ea7123f8fbd1f03bde0d1a557.png

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

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

Title

let vm = new Vue({

el: "#app",

data: {},

methods: {

func3: function () {

console.log("页面不刷新时执行点击提交的函数")

},

}

})

ec1f9d8fbb4e38fab7dc401031714232.png

总结

以上所述是小编给大家介绍的Vue基本使用之对象提供的属性功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值