兄弟传参:通过事件总线(事件车)实现的小demo

本文介绍了一个使用事件总线(EventBus)在Vue.js中实现兄弟组件间通信的小示例,包括创建子组件、配置路由、在main.js中定义EventBus、在组件中绑定变量和事件监听等步骤,最终实现数据的传递和响应。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 事件总线传递思想:就是把事件绑定在这两个兄弟共同访问Vue的实例对象上面

第一步:先创建两个子组件,并在Index.vue文件中引入

<template>
    <div>
        <!-- 兄弟传参需要在 main.js 中写实例对象做桥梁 -->
        <bus-che-01></bus-che-01>
        <bus-che-02></bus-che-02>
    </div>
</template>

<script>
import BusChe01 from './BusChe01.vue'
import BusChe02 from './BusChe02.vue'
    export default {
  components: { BusChe01, BusChe02 },
        
    }
</script>

<style lang="scss" scoped>

</style>

第二步:在router中添加路由

import Vue from 'vue'
import VueRouter from 'vue-router'
import HomeView from '../views/HomeView.vue'
import Demo02 from '../views/Demo02/Index.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/demo02',
    name: 'Demo02',
    component: Demo02
  },
  {
    path: '/',
    name: 'home',
    component: HomeView
  },
  {
    path: '/about',
    name: 'about',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "about" */ '../views/AboutView.vue')
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

export default router

第三步:在main.js里创建自定义$EventBus对象,并存放在原型(prototype)里 

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

Vue.config.productionTip = false

// 事件总线:兄弟传参
const EventBus = new Vue();
// 在原型(prototype)里添加这个实例
Vue.prototype.$EventBus = EventBus


new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')

第四步: 在BusChe01.vue中先绑定一个变量str,通过输入触发search方法

<template>
    <div>
        <input type="text" v-model="str" @input="search">
    </div>
</template>

<script>
    export default {
        data() {
            return {
                str: ''
            }
        },
        methods: {
            search() {
                this.$EventBus.$emit('search', this.str) // 事件总线:'$EventBus'为自定义
                // this.$parent.$emit('search', this.str) 
                // this.$root.$emit('search', this.str)
            }
        },
    }
</script>

<style lang="scss" scoped>

</style>

第五步:在兄弟关系(BusChe02.vue)组件中挂载(mounted)绑定一个事件($on),通过事件函数去触发,让变量str去接收响应结果

<template>
    <div>
        {{str}}
    </div>
</template>

<script>
    export default {
        data() {
            return {
                str: ''
            }
        },
        mounted () {
            // 兄弟传参方法1:事件总线
            this.$EventBus.$on('search',(str)=>{
                this.str = str;
            })

            // 事兄弟传参方法2:$parent
            // 把事件绑定到一个兄弟组件可以访问的公共vue实例对象上
            // this.$parent.$on('search',(str)=>{
            //     this.str = str;
            // })

            // 事兄弟传参方法3(不常用):$root
            // console.log(this.$root)
            // this.$root.$on('search',(str)=>{
            //     this.str = str;
            // })
        },
    }
</script>

<style lang="scss" scoped>

</style>

第六步:最终效果 

 

 

<think>嗯,用户想找关于学生选课信息管理的PTA练习题或解决方案。首先,我需要回忆一下PTA常见的题目类型。PTA通常会有编程题,涉及学生类的设计、集合操作、文件读写等。比如,可能需要创建一个Student类,包含学号、姓名、课程列表等属性,然后实现添加课程、删除课程、查询信息等功能。 用户提到了PTA 6-1,可能这个题目需要处理学生对象集合,比如使用Set或List来存储,并按要求输出信息。根据引用[2],题目可能涉及stuSet放入第四个学生后的对象个数,以及数组stus中的前三个学生的学号和姓名。所以解决方案可能需要正确实现Student类的equals和hashCode方法,确保集合操作正确。 另外,选课系统可能涉及选课逻辑,比如随机踢人、拼手速抢课,如引用[1]提到的。但用户需要的是PTA练习题,所以可能更关注代码实现而非系统设计。可能需要处理并发,但PTA题目通常简化,用基础结构即可。 用户可能需要示例代码,比如Java中的Student类,使用HashSet和ArrayList,并实现添加、删除、查询等方法。需要注意输出格式,比如学号和姓名的拼接方式。此外,异常处理如课程已存在或不存在的情况也要考虑。 相关问题可能涉及数据结构的选用,如Set和List的区别,或者如何优化查询效率。另外,文件操作可能也是PTA题目的一部,比如从文件读取学生信息。需要确保代码符合题目要求的输入输出格式,特别是像PTA这样的自动化评测系统,格式必须严格匹配。</think>根据你的需求,我将从PTA练习题实现角度提供选课信息管理的设计方案和代码示例: ### 一、学生选课系统核心功能 1. 学生类设计:需包含学号、姓名、已选课程集合 2. 课程管理:课程添加/删除/查询 3. 选课逻辑:处理课程冲突、容量限制等 4. 数据持久化:文件读写操作(PTA常见要求) ### 二、Java实现方案示例(适配PTA题型) ```java import java.util.*; class Student implements Comparable<Student> { private String id; private String name; private Set<String> courses = new HashSet<>(); public Student(String id, String name) { this.id = id; this.name = name; } // PTA常见要求的格式输出 @Override public String toString() { return id + ":" + name; } // 用于集合操作 @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Student student = (Student) o; return id.equals(student.id); } @Override public int hashCode() { return Objects.hash(id); } // 实现Comparable接口用于排序 @Override public int compareTo(Student s) { return this.id.compareTo(s.id); } // 选课方法(PTA常见操作) public boolean addCourse(String course) { return courses.add(course); } // 退选方法 public boolean removeCourse(String course) { return courses.remove(course); } } public class CourseManagement { public static void main(String[] args) { Set<Student> stuSet = new HashSet<>(); List<Student> stus = new ArrayList<>(); // 添加测试数据(模拟PTA输入) Collections.addAll(stus, new Student("1001", "张三"), new Student("1002", "李四"), new Student("1003", "王五") ); // 添加第四个学生 stuSet.addAll(stus); Student newStu = new Student("1004", "赵六"); stuSet.add(newStu); // 输出题目要求的结果 System.out.println("stuSet size: " + stuSet.size()); System.out.println("First 3 students:"); stus.stream().limit(3).forEach(System.out::println); } } ``` ### 三、PTA常见考点解析 1. **集合操作**:使用`Set`自动去重,注意重写`equals()`和`hashCode()`[^2] 2. **排序实现**:通过`Comparable`接口实现对象排序 3. **数据封装**:严格遵循题目要求的输出格式(如`学号:姓名`) 4. **异常处理**:课程容量检查、重复选课判断等 ### 四、扩展实现建议 1. 文件读写操作(PTA常见附加要求): ```java // 从文件加载学生数据 public static List<Student> loadStudents(String filename) throws IOException { return Files.lines(Paths.get(filename)) .map(line -> new Student(line.split(",")[0], line.split(",")[1])) .collect(Collectors.toList()); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值