热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

组件定义

1.定义组件并引用2.父组件向子组件传值3.子组件向父组件传值#组件间传值:vuex(https:www.cnblogs.comxiaonqp9697921.html)1.1什么是

1.定义组件并引用

2.父组件向子组件传值

3.子组件向父组件传值 # 组件间传值:vuex (https://www.cnblogs.com/xiaonq/p/9697921.html)


1.1 什么是组件


Html中有组件,是一段可以被复用的结构代码
Css中有组件,是一段可以被复用的样式
Js中有组件,是一段可以被复用的功能
Vue中也有组件,指的就是一个模块,是一个独立的,完整的(包含html,css,js等),可以直接 拿来用的


1.2 组件特性


组件的实例化对象,跟vue实例化对象一样,因此,我们也可以将vue实例化对象看成组件
组件间是独立的,因此数据要独立存储,方法要独立定义, 彼此间不能共享 。

  


2.父组件向子组件传值

2.1 components/Child.vue 定义子组件


<template>
  <div style="color: red">
    <h1>子组件内容h1>
    <p>{{data}}p>
div>
template>
<script>
  export
default {
    
// 子组件要使用父组件的数据,只需要一步,在 props中接收父组件的属性
    props: [data], // 接收父组件给子组件定义的属性
  }
script>

 

2.2 components/Father.vue 定义父组件


<template>
  <div>
    <h1>父组件内容h1>
    父组件显示:{{msg}}
    

    <Child
      
:data=‘msg‘
    
>Child>
  div>
template>
<script>
  // @指定的是src路径
  import Child from @/components/Child // 1.第一步:在父组件中导入子组件
  export default {
    
// 2.第二步:父组件中注册子组件
    components: {
      Child
    },
    data() {
      
return {
        msg:
父组件的信息
      }
    },
    methods: {
    }
  }
script>

 

2.3 router/index.js 中注册路由


import Father from ‘@/components/Father‘ // @修饰符指的是 src目录
export default new Router({
  routes: [
    { path: ‘/component‘, name: ‘Father‘, component: Father },
  ]
})

 

 

2.4 测试

子组件中可以通过 定义 props 属性来接收父组件的数据

技术分享图片

 

 

 

 

 

 


3.子组件向父组件传值

 

3.1 components/Child.vue 子组件通过触发方法, 向父组件传值

 


<template>
  <div>{{data}}
    
<button @click="emitfather">调用父组件方法button>
  div>
template>
<script>
  export
default {
    props: [
data], // 接收父组件给子组件定义的属性
    methods: {
      emitfather() {
        console.log(
调用emitfather方法)
        
//1.子组件调用父组件方法,并传值
        //
$emit 触发当前实例上的事件,也可以简单的理解为触发父组件上的事件(向上冒泡)
        this.$emit(changeMsg, 子组件信息修改后的data信息,传递给父组件)
      }
    }
  }
script>

 

3.2 components/Father.vue 给子组件添加事件及事件处理方法、


<template>
  <div>
    父组件显示:{{msg}}
    

    <Child
      
:data=‘msg‘
      
@changeMsg=‘change‘
    
>Child>
  div>
template>
<script>
  //1.导入
  import Child from @/components/Child
  export
default {
    
//2.注册
    components: {
      Child,
    },
    data() {
      
return {
        msg:
父组件的信息
      }
    },
    methods: {
      
//3.在父组件中定义一个change方法,可以在子组件中触发并传值给父组件
      change(data) {
        
// data接收是子组件中传递的数据
        //
debugger
        alert(调用了父组件的方法, 接收到信息:+data)
        
this.msg = data // 更新父组件的内容
      }
    }
  }
script>

 


3.3 测试

点击 "调用父组件方法" 就会调用

技术分享图片

 


推荐阅读
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • 数字资产量化交易通过大数据分析,以客观的方式制定交易决策,有效减少人为的主观判断和情绪影响。本文介绍了几种常见的数字资产量化交易策略,包括搬砖套利和趋势交易,并探讨了量化交易软件的开发前景。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ... [详细]
  • 解决Win10下MySQL连接问题:Navicat 2003无法连接到本地MySQL服务器(10061)
    本文介绍如何在Windows 10环境下解决Navicat 2003无法连接到本地MySQL服务器的问题,包括启动MySQL服务和检查配置文件的方法。 ... [详细]
  • 本文详细介绍了如何利用Duilib界面库开发窗体动画效果,包括基本思路和技术细节。这些方法不仅适用于Duilib,还可以扩展到其他类似的界面开发工具。 ... [详细]
author-avatar
暗夜风线_371
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有