angular组件间的通信(父子、不同组件的数据、方法的传递和调用)

一、不同组件的传值(使用服务解决)

1、创建服务组件

不同组件相互传递,使用服务组件,比较方便,简单,容易。先将公共组件写在服务的组件里面,如果其他组件使用的话,直接调用即可。

创建服务组件:ng g service 路径(例如:services/storage)

2、配置服务组件:

(1)、在app.module.ts里面配置,引用service

import {StorageService} from "./services/storage.service";

(2)、配置服务(StorageService 是服务的类名)

providers: [StorageService],//所需要的服务

3、使用服务组件:

(1)、需要在使用服务的文件里,引用服务组件(注意路径问题)

import {StorageService} from "../../services/storage.service";

(2)、构造函数初始化

constructor(public storage:StorageService) {
// let s=this.storage.get()
}

(3)、封装服务的组件程序(自己封装为建立、获取、移除)

import { Injectable } from '@angular/core';

@Injectable({
providedIn: 'root'
})
export class StorageService {

constructor() { }
set(key:string,value:any){
localStorage.setItem(key,JSON.stringify(value))
}
get(key){
return JSON.parse(localStorage.getItem(key))
}
remove(key){
localStorage.removeItem(key)
}
}

(4)、调用使用(调用很简单,直接写就ok)

this.storage.set('key',value)
this.storage.get('key')
this.storage.remove('key')

4、写完可以查看是否成功(自己敲的小东西,直接看效果吧)

二、父子组件传值

1、父组件向子组件传值(使用Input)

(1)、子组件引入Input

import { Component, OnInit,Input } from '@angular/core';

@Component({
selector: 'app-header',
templateUrl: './header.component.html',
styleUrls: ['./header.component.scss']
})
export class HeaderComponent implements OnInit {

@Input() title:any;
@Input() home:any;
@Input() run:any;
constructor() { }

ngOnInit(): void {
}
}

(2)、父组件使用子组件时对子组件进行传值(在父组件里)

注:title是字符串、run是方法、home是整个父组件

父组件Html文件

<app-header [title]="title" [run]="run" [home]="this"></app-header>

父组件Ts文件

export class HomeComponent implements OnInit {

public title:string="首页组件的标题"

constructor() { }

ngOnInit(): void {
}
keydown(element){
if(element.target.keyCode=13){
console.log('值:',element.target.keyCode)
this.title='这是已经改变的标题'
}
}
run(){
alert('我是父组件的run方法')
}

}

2、子组件向父组件传值

1)、使用ViewChild

(1)、引用ViewChild

父组件的TS

import { Component, OnInit ,ViewChild,ElementRef} from '@angular/core';
@ViewChild('foot') foot:any

父组件的Html

<app-foot #foot></app-foot>

(2)、调用

this.foot.名字(数据或者是方法等);

2)、使用Output

(1)、引用output、EventEmitter

import { Component, OnInit,Output,EventEmitter } from '@angular/core';

(2)、初始化output

@Output() private  outer=new EventEmitter()

(3)、广播数据(这里我是加的按钮,也可以使用钩子开始就广播,也可以使用某种触发器)

sendmessage(){
this.outer.emit('我是子组件要广播的数据')
}

(4)、调用传值

父组件html

<app-foot (outer)="run($event)"></app-foot>

父组件Ts

run($e){
console.log('shuju',$e)
//alert($e)
}

(5)效果

以上,所有都是自己学习使用,请勿盗用,希望可以对你的学习有所帮助,感谢。

angular组件间的通信(父子、不同组件的数据、方法的传递和调用)的更多相关文章

  1. Vue2不使用Vuex如何实现兄弟组件间的通信

    在一些正规的大型项目的企业级开发过程中我们一般会引入Vuex来对Vue所有组件进行状态管理,可以轻松实现各组件间的通信.但是有时候做做自己的小项目,没有必要使用Vuex时,如何简单的实现组件间的通信? ...

  2. 第四节:Vue表单标签和组件的基本用法,父子组件间的通信

    vue表单标签和组件的基本用法,父子组件间的通信,直接看例子吧. <!DOCTYPE html> <html> <head> <meta charset=&q ...

  3. React中父子组件间的通信问题

    1.https://blog.csdn.net/sinat_17775997/article/details/59103173 (React中父子组件间的通信问题)

  4. ZeroMQ(java)之I/O线程的实现与组件间的通信

    算是开始读ZeroMQ(java)的代码实现了吧,现在有了一个大体的了解,看起来实现是比较的干净的,抽象什么的不算复杂... 这里先来看看它的I/O线程的实现吧,顺带看看是如何实现组件的通信的.... ...

  5. vuejs单一事件管理组件间的通信

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. (尚033)Vue_案例_slot(组件间的通信4:slot)

    1.组件间的通信4:slot(slot:插槽,就是一个占位) slot用于标签反复使用很多次 1.1理解 此方式用于父组件向子组件传递标签数据, 其他为数据通信 外面组件向里面组件传递标签进去,直接拿 ...

  7. Angular 4 组件间的通信

    一.输入属性(父组件与子组件通信) 1. 创建工程 ng new demo1 2.创建order组件 ng g component order 3. 在order组件里定义输入属性 order组件的h ...

  8. Vue 父子组件间的通信

    前言 在 Vue 项目中父子组件的通信是非常常见的,最近做项目的时候发现对这方面的知识还不怎么熟练,在这边做一下笔记,系统学习一下吧. 1 父组件传值给子组件 1.1 传值写法 父组件传值给子组件,这 ...

  9. Vue父子组件间的通信

    父组件通过 props 向下传递数据给子组件,子组件通过 events 向上给父组件发送消息. 父组件: <div> <div style="background:#344 ...

随机推荐

  1. 开机自动挂载本地yum源-20200402-V0.1

    开机自动挂载本地yum源-20200402-V0.1 已下载本地iso /home/Kylin-Server-10-mips64-Release-Build04.08-lic-20200313.iso ...

  2. 3.socket编程示例

    #block_server.py 非阻塞IO示例#有个疑惑:下面的connfd的blockind要设置为True,不然会出错,待解决from socket import *from time impo ...

  3. CSS 重置技术

    元素默认样式显示问题 每个浏览器对不同元素都有自己的默认样式.Google Chrome 渲染正文标题.段落.列表等,与 IE 浏览器可能都有所不同.这就导致同一个页面元素在不同的浏览器中显示效果不一 ...

  4. mysql的日志文件及其作用

    MySQL中有七种日志文件,分别是: 重做日志(redo log) 回滚日志(undo log) 二进制日志(binlog) 中继日志(relay log) 错误日志(errorlog) 慢查询日志( ...

  5. GO学习-(34) Go实现日志收集系统3

    Go实现日志收集系统3   再次整理了一下这个日志收集系统的框,如下图 这次要实现的代码的整体逻辑为: 完整代码地址为: etcd介绍 高可用的分布式key-value存储,可以用于配置共享和服务发现 ...

  6. Go语言web开发---Beego的session

    一.简介 Session是一段保存在服务器上的信息,当客户端第一次访问服务器时创建Session,同时也会创建一个名为beegosessionID,值为创建的Session的id的Cookie. 这个 ...

  7. Jmeter- 笔记10 - 在GUI生成html报告

    步骤1.在聚合报告,浏览一个存放jtl文件的路径,输入不存在的jtl文件,确定后会出现如下图弹窗,不用理会,关掉 步骤2.运行脚本 步骤3.打开工具 -> Generate HTML repor ...

  8. Django(49)drf解析模块源码分析

    前言 上一篇分析了请求模块的源码,如下: def initialize_request(self, request, *args, **kwargs): """ Retu ...

  9. 3D-LaneNet:端到端三维多车道检测ICCV2019

    3D-LaneNet:端到端三维多车道检测ICCV2019 3D-LaneNet: End-to-End 3D Multiple Lane Detection 论文链接: http://openacc ...

  10. CodeGen准备存储库

    CodeGen准备存储库 CodeGen几乎总是与提供用于生成源文件的元数据的存储库结构一起使用,并且许多令牌需要使用存储库结构. 基本要求是有一个结构定义,并且该结构定义包含一个或多个字段定义.有些 ...