Vue2.0父子组件传递函数的教程详解


Posted in Javascript onOctober 16, 2017

Vue.js 是什么

Vue.js (读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计。Vue 的核心库只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与单文件组件和 Vue 生态系统支持的库结合使用时,Vue 也完全能够为复杂的单页应用程序提供驱动。

学习笔记:在vue2.0中,父组件调用子组件时,想要将父组件中的函数体也做传递.

1. 通过props :需要从子组件传参数到父组件时适用

// 父组件.vue

<template>
 <div>
  <ok-input :params='number' :callback='callbackNum'></ok-input>
 </div>
</template>
<script type="text/ecmascript-6">
 import okInput from '../ok-input/okinput.vue';
 export default {
  props: {},
  data() {
   return {
    number: {},
    callbackNum: function (x) {
     console.log(x);
    }
   };
  },
  methods: {
  },
  components: {
   'ok-input': okInput
  }
 };
</script>

// 子组件.vue

<template>
 <div>
   <input v-model='numVal' @change='handleFun'></input>
 </div>
</template>
<script type="text/ecmascript-6">
 import {Input, Select, Option, Button} from 'element-ui';
 import 'element-ui/lib/theme-default/index.css';
 export default {
  props: {
   params: {
    type: Object,
    default: {
     type: ''
    }
   },
   callback: {}
  },
  data() {
   return {
    x: 'hah',  
    numVal: ''
   };
  },
  methods: {
   handleFun(val) {
     this.callback(val); // 将参数传回父组件中的回调函数
   }
  },
  components: {
   'el-input': Input,
  }
 };
</script>

2.通过$emit: 只需获得当前操作对象时适用

// 父组件.vue
<template>
 <div>
  <ok-input :params='inputs' @change='handleAge'></ok-input>
 </div>
</template>
<script type="text/ecmascript-6">
 import okInput from '../ok-input/okinput.vue';
 export default {
  props: {},
  data() {
   return {
    number: {}
   };
  },
  methods: {
   handleAge(evt) {
    console.log(evt.target.value); // 接收从子组件传过来的当前对象
   }
  },
  components: {
   'ok-input': okInput
  }
 };
</script>

// 子组件.vue

<template>
 <div>
   <input v-model='numVal' @blur='handleChange'></input>
 </div>
</template>
<script type="text/ecmascript-6">
 import {Input, Select, Option, Button} from 'element-ui';
 import 'element-ui/lib/theme-default/index.css';
 export default {
  props: {
   params: {
    type: Object,
    default: {
     type: ''
    }
   },
   callback: {}
  },
  data() {
   return {
    x: 'hah',  
    numVal: ''
   };
  },
  methods: {
   handleChange(evt) {
    this.$emit('change', evt); // 将当前对象 evt 传递到父组件
   },
  },
  components: {
   'el-input': Input,
  }
 };
</script>

总结

以上所述是小编给大家介绍的Vue2.0父子组件传递函数的教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript document.referrer 用法
Apr 30 Javascript
Javascript 中创建自定义对象的方法汇总
Dec 04 Javascript
jquery解决客户端跨域访问问题
Jan 06 Javascript
浅谈JSON中stringify 函数、toJosn函数和parse函数
Jan 26 Javascript
JavaScript中实现Map的示例代码
Sep 09 Javascript
node vue项目开发之前后端分离实战记录
Dec 13 Javascript
微信小程序实现MUI数字输入框效果
Jan 31 Javascript
jQuery实现table表格信息的展开和缩小功能示例
Jul 21 jQuery
vue2.0 如何在hash模式下实现微信分享
Jan 22 Javascript
vue watch关于对象内的属性监听
Apr 22 Javascript
JavaScript实现多球运动效果
Sep 07 Javascript
JavaScript实现跟随鼠标移动的盒子
Jan 28 Javascript
使用clipboard.js实现复制功能的示例代码
Oct 16 #Javascript
requireJS模块化实现返回顶部功能的方法详解
Oct 16 #Javascript
JavaScript简单实现合并两个Json对象的方法示例
Oct 16 #Javascript
seajs实现强制刷新本地缓存的方法分析
Oct 16 #Javascript
基于ajax和jsonp的原生封装(实例)
Oct 16 #Javascript
AngularJS实现注册表单验证功能
Oct 16 #Javascript
原生js的ajax和解决跨域的jsonp(实例讲解)
Oct 16 #Javascript
You might like
PHP+DBM的同学录程序(2)
2006/10/09 PHP
谈谈php对接芝麻信用踩的坑
2016/12/01 PHP
php实现微信公众平台发红包功能
2018/06/14 PHP
thinkPHP实现基于ajax的评论回复功能
2018/06/22 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
JS随机漂浮广告代码具体实例
2013/11/19 Javascript
JavaScript不刷新实现浏览器的前进后退功能
2014/11/05 Javascript
JavaScript函数详解
2014/11/17 Javascript
angularjs中的单元测试实例
2014/12/06 Javascript
jQuery 重复加载错误以及修复方法
2014/12/16 Javascript
javascript常用方法总结
2015/05/14 Javascript
js判断radiobuttonlist的选中值显示/隐藏其它模块的实现方法
2016/08/25 Javascript
扩展Bootstrap Tooltip插件使其可交互的方法
2016/11/07 Javascript
微信小程序 闭包写法详细介绍
2016/12/14 Javascript
validationEngine 表单验证插件使用实例代码
2017/06/15 Javascript
Vue.js实现一个todo-list的上移下移删除功能
2017/06/26 Javascript
微信小程序动态添加view组件的实例代码
2019/05/23 Javascript
Vue组件实现触底判断
2019/06/26 Javascript
使用Angular material主题定义自己的组件库的配色体系
2019/09/04 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
如何在Express4.x中愉快地使用async的方法
2020/11/18 Javascript
python list语法学习(带例子)
2013/11/01 Python
python结合selenium获取XX省交通违章数据的实现思路及代码
2016/06/26 Python
对python中if语句的真假判断实例详解
2019/02/18 Python
Python 给屏幕打印信息加上颜色的实现方法
2019/04/24 Python
tensorflow生成多个tfrecord文件实例
2020/02/17 Python
英国内衣连锁店:Boux Avenue
2018/01/24 全球购物
大学生预备党员自我评价分享
2013/11/16 职场文书
十佳班主任事迹材料
2014/01/18 职场文书
党支部创先争优活动总结
2014/08/28 职场文书
新教师培训心得体会
2014/09/02 职场文书
2014年人事工作总结范文
2014/11/19 职场文书
2014年涉外离婚协议书范本
2014/11/20 职场文书
《最后一头战象》读后感:动物也有感情
2020/01/02 职场文书
Mysql 性能监控及调优
2021/04/06 MySQL
mysql分组后合并显示一个字段的多条数据方式
2022/01/22 MySQL