zoukankan      html  css  js  c++  java
  • Vue项目中同级组件传值的例子

    大家好,今天给大家带来Vue项目中同级组件之间传值的例子,父子组件之间的通信比较简单,这里不做讨论。

    假设该项目中的需求如下:

         图1      图中左上角有一个按钮,我们的需求是点击它时,侧边导航栏收缩且主界面放大,如下图所示   

          图2

          因为vue项目是组件化的,那么就有组件之间传值的需求了,下面是具体的编码操作:

           1. 首先在项目的src路径下创建一个js文件,这里命名为byval.js,在该文件中写入如下代码:

    /*jslint esversion:6 */
    import Vue from 'vue';
    export default new Vue();

            2. 在头部组件中(包含点击收缩导航栏按钮)需要传递当前是否收缩侧边导航栏的信息给侧边导航栏和主界面两个组件,所以在头部文件写入如下代码:

    import New from "./new.js";
    
    export default {
      data: function() {
        return {
          isToggle: false// isToggle 是判断是否收缩导航栏的变量,默认为true表示收缩
        };
      },
      methods: {
        // onToggle是处理按钮点击事件的函数
        onToggle: function() {
          // 当点击时,切换当前状态
          this.isToggle = !this.isToggle;
          // 触发 on-toggle-nav 事件并返回当前导航栏的收缩状态变量
          New.$emit("on-toggle-nav", this.isToggle);
        }
      }
    };

      3. 在侧边导航栏组件中,需要接受头部导航栏传递过来的变量,判断当前是否收缩导航栏,所以在侧边导航栏组件中写入如下代码

    export default {
        data:{
            toggle:false,
        }
        ,created(){
             // 绑定on-toggle-nav事件,并在事件触发时,接受头部组件中传来的值
             New.$on("on-toggle-nav", data => {
              // 根据头部中传来的值更新当前组件中对应的变量
              if (data === false) {
                this.toggle = true;
              } else {
                this.toggle = false;
              }
            });
        }
    };

      4. 在主界面中组件中,需要接受头部导航栏中传递过来的变量,判断当前是否最大化主界面,代码逻辑和侧边导航栏组件中的是一致的所以不在此赘述。

    好了,vue项目中同级组件互相传值的过程就是这样啦,谢谢大家的阅读

  • 相关阅读:
    解决pydev无法增加jython271 interpreter的问题
    使用pygal 做chart图的经验分享
    python4delphi 使用
    Some Delphi tips
    http request method and response codes
    flask 项目的开发经验总结
    解决pydev报unsolved import的问题
    python __future__ package的几个特性
    用一个简单的例子来理解python高阶函数
    正确地组织python项目的结构
  • 原文地址:https://www.cnblogs.com/maoqifansBlog/p/11482846.html
Copyright © 2011-2022 走看看