Vue中父组件以及子组件传值问题

Vue中父组件以及子组件传值问题前言:在一些页面中不单单的纯纯的一个vue文件,vue讲究组件化开发,但是一般的肯定会产生交互事件,今天了解了这个传值,特此的来记录一下。目录一.父组件向子组件传值二.子组件向父组件传值一.父组件向子组件传值父组件向子组件传值会用到:Prop,一般的我们需要在子组件中进行相关的声明,如下所示:子组件为HellowWorld.vue<script>exportdefault{name:’HelloWorld’,//接收的变量props:{//声明相关的

大家好,又见面了,我是你们的朋友全栈君。

前言:在一些页面中不单单的纯纯的一个vue文件,vue讲究组件化开发,但是一般的肯定会产生交互事件,今天了解了这个传值,特此的来记录一下。


一.父组件向子组件传值

父组件向子组件传值会用到:Prop,一般的我们需要在子组件中进行相关的声明,如下所示:

子组件为HellowWorld.vue

<script>
export default { 
   
  name: 'HelloWorld',
  //接收的变量
  props: { 
   
  //声明相关的类型
    msg: String,
    count:Number,
    options:[]
  },
  data(){ 
   
    return{ 
   

    }
  },
  methods:{ 
   
  }
}
</script>

在父组件App.vue中

<template>
  <div id="app">
    <!-- msg为字符串类型,count为数字,options为数组 -->
    <HelloWorld msg="First App" :count='count' :options="options"/>
  </div>
</template>

<script> //引入组件 import HelloWorld from './components/HelloWorld.vue' export default { 
      name: 'App', components: { 
      HelloWorld }, data(){ 
      return{ 
      count:0, options:[], } }, methods:{ 
      } } </script>

那么在页面上效果就是:
在这里插入图片描述
当然我们也可以写一些事件来进行动态的数据交互,例如:
在这里插入图片描述

二.子组件向父组件传值

在子组件传值时会用到$emit值得注意的是:在子组件传值时候的方法要与父组件中监听的方法名称相同,也就是示例中的 listenToChild

Helloworld.vue子组件:

<template>
  <div class="hello">
    <!-- 文字信息 -->
    <h1 >{
  
  { msg }}</h1>
    <!-- 数字信息 -->
    <h2>{
  
  {count}}</h2>
    <!-- 渲染数组信息 -->
    <ul>
      <li v-for="(item,index) in options" :key="index">{
  
  {item}}</li>
    </ul>
    <!-- 进行传值 -->
    <button @click="SendMsg">点击</button>
  </div>
</template>

<script> export default { 
      name: 'HelloWorld', props: { 
      msg: String, count:Number, options:[] }, data(){ 
      return{ 
      } }, methods:{ 
      SendMsg(){ 
      // listenToChild 注意 this.$emit('listenToChild',this.options) } } } </script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped> h3 { 
      margin: 40px 0 0; } ul { 
      list-style-type: none; padding: 0; } /* li { display: inline-block; margin: 0 10px; } */ a { 
      color: #42b983; } </style>

App.vue父组件:

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <!-- listenToChild 为子组件传来的方法 -->
    <HelloWorld msg="First App" :count='count' :options="options" @listenToChild="show"/>
    <button @click="Add">+</button>
    <button @click="restart">置零</button>
    <button @click="Sub">-</button>
    <ul>
      <li v-for="(item,index) in data" :key="index">{
  
  {index}},{
  
  {item}}</li>
    </ul>
  </div>

</template>

<script> import HelloWorld from './components/HelloWorld.vue' export default { 
      name: 'App', components: { 
      HelloWorld }, data(){ 
      return{ 
      // 要传去子组件的参数 count:0, options:[], // 子组件传来的参数 data:[] } }, methods:{ 
      Add(){ 
      this.count=Number(this.count)+1 this.options.push('添加一次,当前数值为:'+this.count) }, Sub(){ 
      if(this.count<=0){ 
      this.options.push('当前数值不能变化了'+this.count) }else{ 
      this.count=Number(this.count)-1 this.options.pop() } }, show(data){ 
      console.log(data) this.data=data }, restart(){ 
      this.count=0 this.options=[] } } } </script>

<style> #app { 
      font-family: Avenir, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } button{ 
      margin: 20px; } ul { 
      list-style-type: none; padding: 0; } </style>

效果:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134842.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月3日 上午9:00
下一篇 2022年5月3日 上午9:00


相关推荐

  • pycharn激活2021破解方法

    pycharn激活2021破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    87
  • 腾讯会议obs推流教程_流式编程 前端

    腾讯会议obs推流教程_流式编程 前端 **RTSP视频流开发**RTSP视频开发:1.使用VLC播放RTSP视频流,然后使用wireshark抓VLC的包,找到RTSP交互报文2.报文如下: OPTIONSrtsp://192.168.0.212:554/testStreamRTSP/1.0//客户端向服务器发送,说RTSP服务你又那些操作 CSeq:2 User-Age…

    2022年10月17日
    6
  • 浅谈单调队列

    浅谈单调队列单调队列是指:队列中元素之间的关系具有单调性,而且,队首和队尾都可以进行出队操作,只有队尾可以进行入队操作。队列是一种先进先出(FIFOFirstInFirstOut)的数据结构,它类似于下面这幅图:队列的进出方式类似于平时我们排队打饭,来排队的人从队尾进入,打完饭的人从队头弹出。队列的在程序中储存的方式有很多,OI中最为常用的是使用头指针head和尾指针tail进行存储头指针指…

    2022年6月25日
    35
  • 企业怎么选择国产Web应用防火墙?

    企业怎么选择国产Web应用防火墙?企业怎么选择国产Web应用防火墙?2005年前后,Web应用防火墙(WAF)进入了IT安全领域,最早提供这类产品的供应商是几家新兴公司,如Perfecto、KaVaDo和NetContinuum。工作原理相当简单:随着攻击范围向IP堆栈的上层移动,瞄上针对特定应用的安全漏洞,这时势必需要开发旨在识别和预防这些攻击的产品。虽然网络防火墙在阻止较低层攻击方面很有效,但并不擅长解开IP数据包层,以分析较高层协议;这就意味着,网络防火墙缺少应用感知功能,而要关闭自定义Web应用中的漏洞窗口,就需要这种功能。但是

    2022年5月5日
    39
  • 什么是算法

    什么是算法什么是算法 1 什么是算法算法 algorithm 就是定义良好的计算过程 他取一个或一组的值为输入 并产生出一个或一组值作为输出 简单来说算法就是一系列的计算步骤 用来将输入数据转化成输出结果 mark 我们可以把所有的算法想象为一本 菜谱 特定的算法比如菜谱中的的一道 老醋花生米 的制作流程 只要按照菜谱的要求制作老醋花生米 那么谁都可以做出一道好吃的老醋花生米 so 这个做

    2026年3月19日
    3
  • 传统请求风格 VS RestFul 风格

    传统请求风格 VS RestFul 风格RestFul风格概念Restful就是一个资源定位及资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。功能资源:互联网所有的事物都可以被抽象为资源资源操作:使用POST、DELETE、PUT、GET,使用不同方法对资源进行操作。分别对应添加、删除、修改、查询。传统方式操作资源:通过不同的参数来实现不同的效果!方法单一,post和get​ http://127.0.0.1/item/queryItem.actio

    2022年6月15日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号