最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 21:57:46
文档

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

Vue基本使用之对象提供的属性功能:一 过滤器 过滤器就是vue允许开发者自定义的文本格式化函数, 可以使用在两个地方:输出内容和操作数据中。 1.1 定义过滤器的两种方式 1.1.1 使用Vue.filter()进行全局定义 Vue.filter(RMB1, function(v){ //就是来格式化(处理)v这个数据的
推荐度:
导读Vue基本使用之对象提供的属性功能:一 过滤器 过滤器就是vue允许开发者自定义的文本格式化函数, 可以使用在两个地方:输出内容和操作数据中。 1.1 定义过滤器的两种方式 1.1.1 使用Vue.filter()进行全局定义 Vue.filter(RMB1, function(v){ //就是来格式化(处理)v这个数据的

一 过滤器

过滤器就是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>

总结

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

文档

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

Vue基本使用之对象提供的属性功能:一 过滤器 过滤器就是vue允许开发者自定义的文本格式化函数, 可以使用在两个地方:输出内容和操作数据中。 1.1 定义过滤器的两种方式 1.1.1 使用Vue.filter()进行全局定义 Vue.filter(RMB1, function(v){ //就是来格式化(处理)v这个数据的
推荐度:
标签: 操作 使用 VUE
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top