Как получить отмеченное значение флажка при нажатии кнопки от одного компонента к другому компоненту в angular 6 - PullRequest
0 голосов
/ 10 июля 2020

У меня есть 2 компонента: одна боковая панель и домашний компонент. У меня есть несколько флажков и кнопка в компоненте боковой панели, когда я нажимаю эту кнопку, мне нужно отображать установленное значение флажка на домашнем компоненте. Я уже получаю предупреждение, но как получить значения, я не могу его получить. Вот код ниже

sidebarcomponent. html

<div class="header" *ngIf="router.url !== '/' && router.url !== '/login'">    
            <div class="citilist p-1">List of Cities</div>
            <ul class="p-2">
                <li  class="mb-3 p-1 border-bottom" *ngFor="let city of list;let i = index"><span class="mr-2"><input type="checkbox"></span><span>{{city.city}}</span></li>
            </ul>
            <div class="float-right mr-1 submitbtn"><button (click)="downloadClicked.emit(null)" class="btn btn-primary" type="button">Submit</button></div>
</div>

sidebarcomponent.ts

import { Component, OnInit,Output,EventEmitter} from '@angular/core';
import { Router }  from "@angular/router";
import { CommonserviceService } from './../../utilities/services/commonservice.service';

@Component({
  selector: 'app-sidebar',
  templateUrl: './sidebar.component.html',
  styleUrls: ['./sidebar.component.css']
})
export class SidebarComponent implements OnInit {
  @Output() 
  downloadClicked: EventEmitter<any> = new EventEmitter();

  list: any[] = [{"city":"MOSCOW"},{"city":"TOKYO"},{"city":"LONDON"},{"city":"BRASILIA"},{"city":"NEW DELHI"},{"city":"KATHMANDU"},{"city":"PARIS"}];

  constructor(public router: Router,private commonserviceService: CommonserviceService){} 

  ngOnInit() {
  }

}

homecomponent. html

<div class="row m-0">
    <div class="col-sm-3 p-0 border border-bottom-0 maindiv">
        <app-sidebar (downloadClicked)="generarPDF()"></app-sidebar>
    </div>
    <div class="col-sm-9 p-0"><div class="citilist p-1">Output</div></div>
</div>

homecomponent.ts

import { Component, OnInit,ViewChild, ElementRef } from '@angular/core';
import { CommonserviceService } from './../utilities/services/commonservice.service';
@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent implements OnInit {
  getListData: any;
  constructor(private commonserviceService: CommonserviceService) { }
  @ViewChild('content', { 'static': true}) content:ElementRef;
  name:string;

  ngOnInit() {
     
  }

  generarPDF() {
  this.name="hello";
  alert(this.name);
}
}

Ответы [ 3 ]

0 голосов
/ 10 июля 2020

Я бы собрал все ваши флажки с ViewChildren в вашем компоненте боковой панели. затем отфильтруйте только отмеченные и отправьте значение родительскому компоненту. (Я просто добавил необходимые и измененные строки)

компонент боковой панели. html

<li *ngFor="let city of list;let i = index">
  <input #cbs type="checkbox" value="{{city.city}}">
  {{city.city}}
</li> 
<button (click)="send()">Submit</button>

sidebarcomponent.ts

   @ViewChildren('cbs') cbs;

   send() {
      // filter only checked element  
       const cbsChecked = this.cbs._results.filter(cb => {
         return cb.nativeElement.checked;
       });

       // send city name in defined list
       this.downloadClicked.emit(cbsChecked.map(cb => {
        return {city: cb.nativeElement.value};
       }));
     }

homecomponent.ts

generatePdf(cities) {
    console.log(cities); 
}

ссылка stackblitz: https://stackblitz.com/edit/angular-ivy-vniwxd

0 голосов
/ 10 июля 2020

Рабочая демонстрация в этом Ссылка на StackBlitz

боковая панель. html

<button class="p-half" (click)="checkInputIsChecked()"> Send </button>
<ul class="p-2">
    <li class="mb-3 p-1 border-bottom" (click)="methodCall(cityName.checked, i)" 
       *ngFor="let city of list;let i = index">
       <span class="mr-2">
          <input #cityName [id] = "i" [checked]="city?.isChecked" 
                 [value]="city" type="checkbox">
       </span>
       <label [for]="i" >{{city.city}}</label>
    </li>
</ul>

sidebar.ts

list: any[] = [
               { "city":"MOSCOW" }, 
               { "city":"TOKYO" },
               { "city":"LONDON" },
               { "city":"BRASILIA" },
               { "city":"NEW DELHI" },
               { "city":"KATHMANDU" },
               { "city":"PARIS"}
              ];
checkedList;
@Output() downloadClicked: EventEmitter<any> = new EventEmitter<any>();
constructor() { }
ngOnInit() { 
}
methodCall(inn, inputIndex){
   this.list[inputIndex] = {...this.list[inputIndex], 'isChecked': !inn};
}
checkInputIsChecked(){
   this.checkedList = this.list.filter(item => item.isChecked === true);
   this.downloadClicked.emit(this.checkedList);
}

Home. html

<code><div class="container">
     <div class="sidebar p-1">
          <app-sidebar (downloadClicked) ="checkedInput($event)"></app-sidebar>
     </div>
     <div class="main p-1">
         <p>This is Home Main Content</p>
         <pre>
              {{inputChecked |json}}
         

home.ts

inputChecked;
constructor() { }
ngOnInit() {
}
checkedInput(allCheckedInput){
   this.inputChecked = allCheckedInput;
} 
0 голосов
/ 10 июля 2020

Нам нужно будет установить переменную уровня класса для отслеживания выбранного значения через текстовое поле. Мы можем сделать это с помощью этих обновлений.

компонент боковой панели. html

<div class="header">
  <div class="citilist p-1">List of Cities</div>
  <ul class="p-2">
    <li class="mb-3 p-1 border-bottom" *ngFor="let city of list;let i = index">
      <span class="mr-2">
        <!-- This allows us to set the class level variable of city to the correct city.  -->
        <input type="checkbox" (change)="citySelected(city.city)" />
      </span>
      <span>{{city.city}}</span>
    </li>
  </ul>
  <div class="float-right mr-1 submitbtn">
    <button
      <!-- Here, we're going to emit that class level variable of city.  -->
      (click)="downloadClicked.emit(city)"
      class="btn btn-primary"
      type="button"
    >
      Submit
    </button>
  </div>
</div>

sidebarcomponent.ts

import { Component, OnInit,Output,EventEmitter} from '@angular/core';
import { Router }  from "@angular/router";
import { CommonserviceService } from './../../utilities/services/commonservice.service';

@Component({
  selector: 'app-sidebar',
  templateUrl: './sidebar.component.html',
  styleUrls: ['./sidebar.component.css']
})
export class SidebarComponent implements OnInit {
  @Output() downloadClicked: EventEmitter<any> = new EventEmitter();

  list: any[] = [
    { city: "MOSCOW" },
    { city: "TOKYO" },
    { city: "LONDON" },
    { city: "BRASILIA" },
    { city: "NEW DELHI" },
    { city: "KATHMANDU" },
    { city: "PARIS" }
  ];

  city = "";

  constructor(
    public router: Router,
    private commonserviceService: CommonserviceService
  ) {}

  ngOnInit() {}

  citySelected(city) {
    this.city = city;
  }
}

homecomponent. html

<div class="row m-0">
  <div class="col-sm-3 p-0 border border-bottom-0 maindiv">
    <!-- Notice that we're passing in a $event value here. -->
    <app-test (downloadClicked)="generarPDF($event)"></app-test>
  </div>
  <div class="col-sm-9 p-0">
    <div class="citilist p-1">
      Output
    </div>
  </div>
</div>

homecomponent.ts

import { Component, OnInit,ViewChild, ElementRef } from '@angular/core';
import { CommonserviceService } from './../utilities/services/commonservice.service';
@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent implements OnInit {
@ViewChild("content", { static: true }) content: ElementRef;
  getListData: any;
  name: string;

  constructor(private commonserviceService: CommonserviceService) {}

  ngOnInit() {}

  generarPDF(event) {
    alert(event);
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...