冇事来学系--Vue2.0中组件化编码流程与数据传递

简介: 组件之间的数据传递

组件之间的数据传递


父传子

父组件写数据,并且在使用子组件标签的时候传递数据;

子组件在props节点中设置自定义属性,用于接收父组件的数据,接收的数据在子组件实例对象vc中,可以直接在模板中使用


子传父

在父组件中 (methods节点下) 写一个接收函数receive,设置一个形参x来接收子组件的数据,并且在使用子组件的时候传递这个函数;(:recieve="recieve")

子组件在props节点设置自定义属性,来接收父组件传来的函数 (props: [recieve]) ,接收的函数在子组件的实例对象vc身上,可以直接在模板中使用,也可以在methods节点中的事件处理函数里面通过this调用这个函数,并把数据作为实参传递( this.receive(数据) )

通过传参实现数据传递


父传孙

通过逐级传递,由父传子,子再传孙

父组件写数据,并且在使用子组件标签的时候传递数据;

子组件的props节点设置自定义属性接收,并且在子组件中使用孙组件的时候写入这个属性来传递

孙组件的props节点设置自定义属性接收子组件传来的数据,接收的数据在孙组件的实例对象vc上,可以直接在模板中使用


数据传递

  1. 实现静态组件:抽取组件,使用组件实现静态页面的效果
  2. 展示动态数据
  1. 数据类型、名称是啥

一堆数据用数组来存储,每一个数据又很多属性则用对象来表示

  1. 数据保存在哪个组件:
  1. 数据是一个组件在用 --> 放在组件自身即可
  2. 数据是一些组件在用 --> 放在他们共同的父组件上(状态提升)

注意:使用v-model时要注意不能绑定props里面的值,因为props里面的值是不允许被修改的

  1. 实现交互:从绑定事件开始

一般数据在哪里,操作数据的方法就在哪里(增删改查)

nanoid的使用--> 用于生成id

nanoid是一个函数,直接调用就会生成一个唯一的字符串

安装nanoid的库 ---> npm i nanoid

引入nanoid ---> import {nanoid} from 'nanoid' (nanoid使用了分别暴露)

使用: nanoid( )

  1. 交互,从绑定事件监听开始

组件化编码流程

目录
相关文章
|
8天前
|
监控 JavaScript 前端开发
使用Vue.js开发员工上网行为监控的实时数据展示页面
使用Vue.js开发的实时员工上网行为监控页面,展示员工访问的网站、应用和时间等数据。页面响应式设计,适应不同设备。通过Vue组件显示实时数据,如`<li v-for="activity in activities">`循环渲染。数据定时更新,利用Vue的生命周期钩子和axios从服务器获取并自动刷新,确保数据的时效性。该页面有助于管理者即时了解员工网络活动,保障企业网络安全和资源管理。
46 5
|
1月前
|
JavaScript 前端开发 开发者
响应式原理:Vue 如何跟踪数据变化
【4月更文挑战第22天】Vue 的响应式系统是其核心,通过数据双向绑定实现视图与数据同步。依赖收集和观测数据使Vue能跟踪变化,变化通知组件更新视图。高效的更新策略如批量更新和虚拟DOM提升性能。组件化和可组合性支持有效通信和代码复用,强调数据驱动开发。开发者应合理组织数据、谨慎处理变更并充分利用组件化优势,以提高效率和用户体验。
|
1月前
Vue3响应式数据ref
Vue3响应式数据ref
|
1月前
Vue3 子传父 暴露数据 defineExpose
Vue3 子传父 暴露数据 defineExpose
Vue3 子传父 暴露数据 defineExpose
|
10天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的共享单车数据存储系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的共享单车数据存储系统附带文章源码部署视频讲解等
9 1
|
10天前
|
JavaScript
vue数据的双向绑定
vue数据的双向绑定
|
15天前
|
JavaScript
|
17天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的旅游数据附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的旅游数据附带文章源码部署视频讲解等
13 0
|
1月前
|
JavaScript
vue3表格编辑(数据回显)和删除功能实现
vue3表格编辑(数据回显)和删除功能实现
25 1
|
1月前
|
JavaScript 索引
vue 在什么情况下在数据发生改变的时候不会触发视图更新
vue 在什么情况下在数据发生改变的时候不会触发视图更新
35 2