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>

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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • nactive15激活码_最新在线免费激活2022.02.11「建议收藏」

    (nactive15激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html4KDDGND3CI-eyJsaWN…

  • UE4->Plugin 认识UE4插件 1「建议收藏」

    UE4->Plugin 认识UE4插件 1「建议收藏」本文带大家认识UE4的插件,PluginUE4Engine中插件代码占很大一部分,可参考下图,里面的Editor,Developer,Runtime,Slate举例都是大家比较熟悉的几个1>看下图的中Json,其实就是我们的.plugin文件{ “FileVersion”:3, //文件版本 “Version”:1, //Plugin版本 “VersionName”:”1.0″, //版本名称 “FriendlyName”:”Taskp”, //插件名称 “Des

  • 天谕最炫民族风曲谱_最炫民族风萨克斯五线谱

    天谕最炫民族风曲谱_最炫民族风萨克斯五线谱天谕手游最炫民族风乐谱代码是什么?《最炫民族风》是凤凰传奇演唱的一首流行歌曲,由张超作词和谱曲,发行于2009年5月27日,是其第三张专辑《最炫民族风》的主打歌。接下来小编为大家带来了天谕手游最炫民族风乐谱代码分享,希望可以帮助到大家。最炫民族风【音轨1】l8r1r1r1r1r1r1r1r1r1r1v>d1&d2&dv15bb1&b2v15f+v15f+2.&…

  • Python-爬取HTML网页数据

    Python-爬取HTML网页数据Python-爬取HTML网页数据软件环境Mac10.13.1(17B1003)Python2.7.10VSCode1.18.1摘要本文是练手Demo,主要是使用BeautifulSoup来爬取网页数据。BeautifulSoup介绍BeautifulSoup提供一些简单的、python式的用来处理导航、搜索、修改分析树等功能。BeautifulSoup官方

  • Oracle 正则表达式以及常用正则函数

    Oracle 正则表达式以及常用正则函数Oracle正则表达式以及常用函数正则表达式简介正则表达式基础Oracle常用函数正则表达式简介菜鸟教程练习网站1练习网站2练习网站3练习网站4软件下载什么是正则表达式?正则表达式,又称规则表达式。(英语:RegularExpression,在代码中简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。什么时候会用到正则表达式?数据验证字符串查找字符串替换正则表达式基础元字符描述

  • BM3D算法学习

    BM3D算法学习来源:BM3D算法学习-知乎(zhihu.com)作者:爱酷的胡巴前些日子在学习图像降噪的算法,自然而然的发现了这篇里程碑式的作品,“BM3D”3D块匹配降噪算法,想来时间也久,赶紧再写下来,以免过后忘记。在学习的过程中,由于没学过数字图像处理,学起来还是挺墨迹的,前前后后得有四五天吧,才算整个大差不差,期间看了许多前辈的博客和代码,也总算有些许的进步和理解,特此感…

发表回复

您的电子邮箱地址不会被公开。

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