当前位置: 首页 > news >正文

python做网站好不好网站免费seo

python做网站好不好,网站免费seo,嘉兴网站建设方案优化,网站建设模板能实现按钮跳转吗目录 1.父传后代 ( 后代拿到了父的数据 )1. 父组件引入子组件,绑定数据2. 子组件直接使用父组件的数据3. 依赖注入(使用 provide/inject API)1.在祖先组件中使用 provide2.在后代组件中使用 inject 2.后代传父 (父拿到了后代的数据)1. 子组件…

目录

  • 1.父传后代 ( 后代拿到了父的数据 )
    • 1. 父组件引入子组件,绑定数据
    • 2. 子组件直接使用父组件的数据
    • 3. 依赖注入(使用 provide/inject API)
      • 1.在祖先组件中使用 provide
      • 2.在后代组件中使用 inject
  • 2.后代传父 (父拿到了后代的数据)
    • 1. 子组件传值给父组件
      • 子组件中:
      • 父组件中:
    • 2. 父组件直接拿到子组件的数据
  • 3.平辈之间的传值 ( 兄弟可以拿到数据 )
      • 创建 bus.js 文件

1.父传后代 ( 后代拿到了父的数据 )

1. 父组件引入子组件,绑定数据

<List :str1=‘str1’></List>

子组件通过props来接收
props:{str1:{type:String,default:''}}
***这种方式父传子很方便,但是父传给孙子辈分的组件就很麻烦(父=》子=》孙)
这种方式:子不能直接修改父组件的数据

2. 子组件直接使用父组件的数据

子组件通过:this.$parent.xxx使用父组件的数据
这种方式:子可以直接修改父组件的数据

3. 依赖注入(使用 provide/inject API)

优势:父组件可以直接向某个后代组件传值(不让一级一级的传递)

在这里插入图片描述

1.在祖先组件中使用 provide

在祖先组件中,你可以使用 provide 选项来提供数据或方法。这些数据或方法可以被任何后代组件通过 inject 选项来接收。

<!-- AncestorComponent.vue -->  
<template>  <div>  <DescendantComponent />  </div>  
</template>  <script>  
import DescendantComponent from './DescendantComponent.vue';  export default {  components: {  DescendantComponent  },  provide() {  return {  foo: 'foo',  myMethod: this.myMethod  };  },  methods: {  myMethod() {  console.log('This is a method from AncestorComponent.');  }  }  
};  
</script>

2.在后代组件中使用 inject

在后代组件中,你可以使用 inject 选项来接收在祖先组件中 provide 的数据或方法。

<!-- DescendantComponent.vue -->  
<template>  <div>  <p>{{ foo }}</p>  <button @click="callAncestorMethod">Call Ancestor Method</button>  </div>  
</template>  <script>  
export default {  inject: ['foo', 'myMethod'],  methods: {  callAncestorMethod() {  this.myMethod();  }  }  
};  
</script>

在这个例子中,DescendantComponent 接收了 foo 字符串和 myMethod 方法,它们都是在 AncestorComponent 中通过 provide 提供的。

2.后代传父 (父拿到了后代的数据)

1. 子组件传值给父组件

子组件定义自定义事件 this.$emit

子组件中:

// ChildComponent.vue  
export default {  methods: {  sendToParent() {  this.$emit('child-event', 'Data from child');  }  }  
};

父组件中:

<!-- ParentComponent.vue -->  
<template>  <div>  <ChildComponent @child-event="handleChildEvent" />  </div>  
</template>  <script>  
// ...  
export default {  // ...  methods: {  handleChildEvent(data) {  console.log('Received data from child:', data);  }  }  
};  
</script>

2. 父组件直接拿到子组件的数据

<List ref=‘child’></List>
this.$refs.child

下面是一个简单的例子,展示了如何在父组件中通过 $refs 访问子组件的方法:

<!-- ChildComponent.vue -->  
<template>  <div>  <button @click="sayHello">Say Hello</button>  </div>  
</template>  <script>  
export default {  methods: {  sayHello() {  console.log('Hello from ChildComponent!');  }  }  
};  
</script>  <!-- ParentComponent.vue -->  
<template>  <div>  <ChildComponent ref="child" />  <button @click="callChildMethod">Call Child's Method</button>  </div>  
</template>  <script>  
import ChildComponent from './ChildComponent.vue';  export default {  components: {  ChildComponent  },  methods: {  callChildMethod() {  this.$refs.child.sayHello(); // 调用子组件的 sayHello 方法  }  }  
};  
</script>

在这个例子中,点击父组件的按钮会触发 callChildMethod 方法,该方法通过 this.$refs.child.sayHello() 调用了子组件的 sayHello 方法。

3.平辈之间的传值 ( 兄弟可以拿到数据 )

通过新建bus.js文件来做

在 Vue.js 中,如果你想要在不直接依赖父子组件关系的情况下进行组件间的通信,一个常见的方法是创建一个全局的事件总线(Event Bus)。你可以通过创建一个新的 Vue 实例来作为这个事件总线,并在你的组件中通过它来进行事件的触发($emit)和监听($on)

以下是如何通过新建一个 bus.js 文件来创建全局事件总线的步骤:

创建 bus.js 文件

在你的项目根目录或合适的地方,创建一个 bus.js 文件,并导出一个新的 Vue 实例:

// bus.js  
import Vue from 'vue';  export const EventBus = new Vue();

在组件中触发事件 ,在你的组件中,你可以导入 EventBus 并使用 $emit 方法来触发事件:

// ChildComponent.vue  
<template>  <button @click="notify">Notify Parent</button>  
</template>  <script>  
import { EventBus } from './bus.js'; // 假设 bus.js 和当前文件在同一目录下  export default {  methods: {  notify() {  EventBus.$emit('child-event', 'Data from child');  }  }  
};  
</script>

在组件中监听事件, 在另一个组件中,你可以导入 EventBus 并使用 $on 方法来监听事件:

// ParentComponent.vue 或其他任何组件  
<script>  
import { EventBus } from './bus.js'; // 假设 bus.js 和当前文件在同一目录下  export default {  created() {  EventBus.$on('child-event', (data) => {  console.log('Received data from child:', data);  });  },  beforeDestroy() {  // 清除事件监听,避免内存泄漏  EventBus.$off('child-event');  }  
};  
</script>

注意,在组件销毁(beforeDestroy 或 destroyed 钩子)时,你应该使用 $off 方法来移除事件监听器,以避免内存泄漏。

使用事件总线的一个缺点是它可能导致你的应用状态变得难以追踪,特别是当你的应用变得复杂并且有很多组件在相互通信时。因此,尽管事件总线在某些场景下很有用,但在设计你的应用架构时,也要考虑其他状态管理解决方案,如 Vuex。

http://www.yidumall.com/news/70695.html

相关文章:

  • 网站建设思路方案省好多会员app
  • 产品review网站怎么做aso优化推广
  • 个人做 网站2019seo网站推广有哪些
  • 建立网站有怎么用途168推广网
  • 南京做网站南京乐识最优北京计算机培训机构哪个最好
  • 番禺网站开发哪家专业企业培训课程表
  • 北京的做网站公司惠州seo报价
  • 让网站会员做产品标签确认网络营销方案如何写
  • 平台型网站建设微商引流人脉推广软件
  • 选择网站开发公司的标准怎么推广销售
  • 买了网站 怎么做呢关键词优化课程
  • 建站系统模板百度招聘网最新招聘信息
  • 怎么注册晋江网站做的搜索引擎都有哪些
  • 网站建设项目简介个人网站的制作模板
  • Godaddy优惠码网站怎么做的网店培训
  • 做外包的网站有哪些问题现代网络营销的方式
  • 电商网站建设 网站定制开发广东省最新新闻
  • 天津网站建设软件开发招聘淘宝网店的seo主要是什么
  • 公司网站集群系统架构及建设思路徐州网站设计
  • 辽宁高端网站建设有什么平台可以发布推广信息
  • 网站内链google搜索引擎下载
  • 怎么自己做彩票网站吗aso优化技术
  • 网上做翻译兼职网站好推广方式
  • 外贸网站是用什么软件做的北京seo排名服务
  • 学校网站制作方案网络营销模式有哪些?
  • 衢州集团网站建设宁波网站推广公司价格
  • 网站长春网站建设百度的代理商有哪些
  • 丰镇市网站hao123上网从这里开始官方
  • 北京市公共资源交易服务平台seo自学网官方
  • 网站建设相对路径seo是啥