vue 数据操作相关总结


Posted in Vue.js onDecember 17, 2020

vue中有很多有关数据的操作方法,比如父子组件数据的传递,子组件修改父组件数据,props,computed,watch,sync等,今天就来总结一下这些操作方法的使用

computed是计算属性

computed是计算属性:减少模板{{}}的复杂度。 在模板中放入太多的逻辑会让模板过重且难以维护。对于任何复杂逻辑,你都应当使用计算属性 把复杂的运算逻辑写到computed的函数里面,再在模板里引用就使逻辑变得简单明了了 使用方法: computed与data并列,将一系列操作封装成一个方法,放到computed里,调用时直接写方法名,不用加( )

new Vue({
 el:"#app",
 data:{
  user:{
   email:"dong@qq.com",
   nickname:"oldUath",
   phone:"12812345678"
  }
 },
 //计算属性
 computed:{
  displayName(){
    //返回一个结果
   const user=this.user
   return user.nickname ||user.phone||user.email
  }
 },
 template:`
   <div>
   {{displayName}}
   </div>
 `
})

watch侦听器

watch:侦听器:观察Vue实例上的数据变动,只要指定的数据改变就会执行预定的函数 当需要在数据变化时执行异步或开销较大的操作时;

watch使用方法一:

<div id="app">
    {{msg}} 
    <br> 
    改变了吗? {{isChange}}
    <button @click="change">改变</button>
  </div>
  new Vue({
   el: "#app",
   data: {
   		//这是第一层数据
      msg:'欲穷千里目',
     	isChange:'No',
      user:{
      	//这是第二层数据
        name:"oldUath",
        phone:'18312345678'
      }
   },
   watch:{
    //只要msg改变,这个方法就会执行,第一层数据只需要写 数据名(){}就可以
    msg(val,oldVal){
      this.isChange = 'Yes'
    },
    //第二层数据需要'','user.name'(){}
    'user.name'(){
    	console.log('user.name变了')
    }
   },
   methods:{
    change(){
      this.msg = '更上一层楼'
    }
   }
  })

注意:在vue里面如果把一个对象原封不动的再赋值给他,那么他的地址就变了

//obj:{a:'a'}
obj.a+='hi'//才是监听obj时,因为obj地址没有发生变化,所以不会执行监听obj的事件

可以使用 deep:true这个是代表让watch往深处监听,值变了就相当于改变了

watch:{
	obj(){
  		handle(){console.log('obj变了')
  	},
  	 deep:true
}

使用方法二: vm.$watch('监听的变量',调用的函数,{immediate:true})

与方法一的效果相同

const vm = new Vue({
   el: "#app",
   data: {
      msg:'欲穷千里目',
     	isChange:'No',
      user:{
        name:"oldUath",
        phone:'18312345678'
      }
   },
   methods:{
    change(){
      this.msg = '更上一层楼'
    }
   }
  })
  vm.$watch('msg',function(){
  		console.log('n变了')
  },{immediate:true})

父组件给子组件传递数据: Props

父组件要想给子组件传入数据,需要在子组件种使用Props引入变量

父组件要给子组件出入 money="100"
先在父组件种传入

//在父组件调用子组件
<Child :money="100"><Child>

再在子组件种引入数据,引入money这个变量

<template>
<div class="red">
+  {{money}}元
 <button>花钱</button>
</div>
</template>
<script>
export default {
+ props:['money']
}
</script>

此时子组件只能使用父组件的数据,而不能修改

子组件修改父组件的数据(.sync原理)

组件不能直接修改props外部的数据

使用$emit进行修改

在子组件使用 $emit(‘参数1',参数2)

当前实例继承了eventBus,可以触发一个事件

在子组件写$emit,第一个参数是事件名,第二个参数是修改后的值

<!-- $emit()触发一个事件,update:money是事件名  -->
<button @click="$emit('update:money',money-10)">花钱</button>

在父组件使用 $event接受参数2;

$event就是接收子组件参数2返回的结果的

<!--  传给子组件一个money值,v-on是监听子组件的update:money事件,
      $event获取子组件事件的结果-->
  <Child :money="total" v-on:update:money="total = $event" />

简化结果: sync

父组件这一大段代码太麻烦了,vue把它封装成了一个修饰符

<Child :money.sync="total" />

子组件还是那样写

这个只解决了父子组件的通信问题,兄弟组件的通信问题呢?

兄弟组件通信:emit/emit/on

这种方法通过一个空的Vue实例作为中央事件总线(事件中心),用它来触发事件和监听事件,巧妙而轻量地实现了任何组件间的通信,包括父子、兄弟、跨级。当我们的项目比较大时,可以选择更好的状态管理解决方案vuex。 具体实现方式

var Event=new Vue();
  Event.$emit(事件名,数据);//传递事件数据
  Event.$on(事件名,data => {});//接受数据

举个例子:A组件向C组件传递信息,ABC是相邻组件

首先在A组件提供事件数据使用$emit,第一个参数是数据名,要与接收数据的on的第一个参数相同;第二个参数是数据

<template id="a">
 <div>
  <h3>A组件:{{name}}</h3>
  <button @click="send">将数据发送给C组件</button>
 </div>
</template>

<script>
var Event = new Vue();//定义一个空的Vue实例
var A = {
  template: '#a',
  data() {
   return {
    name: 'tom'
   }
  },
  methods: {
   send() {
    Event.$emit('data-a', this.name);
   }
  }
}
</script>

在C组件接受数据 $on,第一个参数是数据名,第二个参数用来接收数据

<template id="c">
 <div>
  <h3>C组件:{{name}},{{age}}</h3>
 </div>
</template>
<script>

var Event = new Vue();//定义一个空的Vue实例
var C = {
  template: '#c',
  data() {
   return {
    name: '',
    age: ""
   }
  },
  mounted() {//在模板编译完成后执行
   Event.$on('data-a',name => {
     this.name = name;//箭头函数内部不会产生新的this,这边如果不用=>,this指代Event
   })
  }
}
</script>

总结

  • 父子之间传递数据用 props$emit
  • 兄弟之间传递数据用 $emit$on
  • 父组件向孙子组件传递数据使用 provideinject

以上就是vue 数据操作相关总结的详细内容,更多关于vue 数据操作的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
vue+elementUI动态增加表单项并添加验证的代码详解
Dec 17 Vue.js
vue3使用vue-count-to组件的实现
Dec 25 Vue.js
vue 使用class创建和清除水印的示例代码
Dec 25 Vue.js
为什么推荐使用JSX开发Vue3
Dec 28 Vue.js
学习 Vue.js 遇到的那些坑
Feb 02 Vue.js
vue使用v-model进行跨组件绑定的基本实现方法
Apr 28 Vue.js
vue使用节流函数的踩坑实例指南
May 20 Vue.js
Vue的生命周期一起来看看
Feb 24 Vue.js
VUE中的v-if与v-show区别介绍
Mar 13 Vue.js
Vue.Draggable实现交换位置
Apr 07 Vue.js
vue使用watch监听属性变化
Apr 30 Vue.js
vue3不同环境下实现配置代理
May 25 Vue.js
Vue 组件注册全解析
Dec 17 #Vue.js
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 #Vue.js
vue实现图片裁剪后上传
Dec 16 #Vue.js
Vue-router中hash模式与history模式的区别详解
Dec 15 #Vue.js
vue项目中企业微信使用js-sdk时config和agentConfig配置方式详解
Dec 15 #Vue.js
Vue解决移动端弹窗滚动穿透问题
Dec 15 #Vue.js
8个非常实用的Vue自定义指令
Dec 15 #Vue.js
You might like
php地址引用(php地址引用的效率问题)
2012/03/23 PHP
thinkPHP5.0框架配置格式、加载解析与读取方法
2017/03/17 PHP
phpstorm 正则匹配删除空行、注释行(替换注释行为空行)
2018/01/21 PHP
PHP实现的无限分类类库定义与用法示例【基于thinkPHP】
2018/08/06 PHP
用 javascript 实现的点击复制代码
2007/03/24 Javascript
JavaScript的变量作用域深入理解
2009/10/25 Javascript
jquery 简短几句代码实现给元素动态添加及获取提示信息
2011/09/01 Javascript
获取body标签的两种方法
2011/10/13 Javascript
window.event快达到全浏览器支持了,以后使用就方便了
2011/11/30 Javascript
javascript提取URL的搜索字符串中的参数(自定义函数实现)
2013/01/22 Javascript
jquery eval解析JSON中的注意点介绍
2013/08/23 Javascript
JavaScript中Function详解
2015/02/27 Javascript
jQuery封装的tab选项卡插件分享
2015/06/16 Javascript
JS模拟酷狗音乐播放器收缩折叠关闭效果代码
2015/10/29 Javascript
在其他地方你学不到的jQuery小贴士和技巧(欢迎收藏)
2016/01/20 Javascript
JS表格组件神器bootstrap table详解(强化版)
2016/05/26 Javascript
ionic开发中点击input时键盘自动弹出
2016/12/23 Javascript
详解Vue 开发模式下跨域问题
2017/06/06 Javascript
JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案
2017/06/30 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
angular中实现li或者某个元素点击变色的两种方法
2017/07/27 Javascript
使用apifm-wxapi快速开发小程序过程详解
2019/08/05 Javascript
[02:51]DOTA2 Supermajor小组分组对阵抽签仪式
2018/06/01 DOTA
python实现的二叉树算法和kmp算法实例
2014/04/25 Python
使用Python编写一个最基础的代码解释器的要点解析
2016/07/12 Python
利用Python进行异常值分析实例代码
2017/12/07 Python
pyqt5 实现在别的窗口弹出进度条
2019/06/18 Python
python之yield和Generator深入解析
2019/09/18 Python
Pytorch转onnx、torchscript方式
2020/05/25 Python
Tensorflow全局设置可见GPU编号操作
2020/06/30 Python
Python代码需要缩进吗
2020/07/01 Python
美国韩国化妆品和护肤品购物网站:Beautytap
2018/07/29 全球购物
成人高等教育毕业生自我鉴定
2013/10/22 职场文书
大学生自我评价怎样写好
2013/10/23 职场文书
捐助倡议书
2015/01/19 职场文书
幼儿园辞职书
2015/02/26 职场文书