NG-ZORRO Слайдер Угловой 7 - PullRequest
       6

NG-ZORRO Слайдер Угловой 7

0 голосов
/ 30 ноября 2018

Надеюсь, что кто-нибудь может пролить свет на это.

У меня есть проект Angular 7 с ng-zorro.

Это мой app.component.html

    <nz-layout>
     <nz-header>Header</nz-header>
     <nz-layout>
     <nz-sider>Sider</nz-sider>
     <nz-content>
      <div nz-row>
       <div nz-col nzSpan="20" nzOffset="2">
        <h5>Drawer without Service</h5>
          <button nz-button nzType="primary" 
       (click)="open()">Open</button>
          <nz-drawer [nzClosable]="false" [nzVisible]="isOpen" 
             [nzWidth]="320" nzTitle="Basic Drawer" 
        (nzOnClose)="close()">
            <p>Slider</p>
            <nz-slider
                nzDots nzRange
                [nzMarks]="marks"
                [nzStep]="1" [nzMin]="1" [nzMax]="maxMark"
                [nzDefaultValue]="selectedMark">
            </nz-slider>
          </nz-drawer>
        </div>
      </div>
      <div nz-row>
        <div nz-col nzSpan="20" nzOffset="2">
          <div>
            <h5>Drawer with Service</h5>
            <button nz-button nzType="primary" 
    (click)="openDrawer()">Open</button>
          </div>
        </div>
      </div>
    </nz-content>
  </nz-layout>
  <nz-footer>Footer</nz-footer>
   </nz-layout>

И это мое app.component.ts

import { Component, Input } from '@angular/core';
import { NzDrawerService, NzDrawerRef } from 'ng-zorro-antd';

@Component({
  selector: 'custom-drawer',
  template: `
    <p><button nz-button nzType="dashed" (click)="close()">Close</button></p>
    <nz-slider
      nzDots nzRange
      [nzStep]="1" [nzMin]="1" [nzMax]="maxMark"
      [nzMarks]="marks"
      [nzDefaultValue]="selectedMark">
    </nz-slider>
  `
})
export class CustomDrawerComponet {
  @Input() marks: {};
  @Input() selectedMark;
  get maxMark() { return Object.keys(this.marks).length; }
  constructor(private drawerRef: NzDrawerRef) {
  }

  close() {
    if (this.maxMark === 5) {
      this.marks = {
        1: 'M1',
        2: 'M2',
        3: 'M3'
      };
    } else {
      this.marks = {
        1: 'M1',
        2: 'M2',
        3: 'M3',
        4: 'M4',
        5: 'M5'
      };
    }
    this.drawerRef.close('Closed!');
  }
}

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.scss']
})
export class AppComponent {
  title = 'NG Zorro Playground';
  isOpen = false;
  marks: any = {
    1: 'M1',
    2: 'M2',
    3: 'M3'
  };
  get maxMark() { return Object.keys(this.marks).length; }
  selectedMark = [2, 2];

  constructor(private drawerService: NzDrawerService) { }
  close() {
    this.changeMarks();
    this.isOpen = false;
  }

  open() {
    this.isOpen = true;
  }

  changeMarks() {
    if (this.maxMark === 5) {
      this.marks = {
        1: 'M1',
        2: 'M2',
        3: 'M3'
      };
    } else {
      this.marks = {
        1: 'M1',
        2: 'M2',
        3: 'M3',
        4: 'M4',
        5: 'M5'
      };
    }
  }

  openDrawer() {
    const drawerRef = this.drawerService.create({
      nzTitle: 'Drawer Basic From Service',
      nzWidth: 320,
      nzClosable: true,
      nzContent: CustomDrawerComponet,
      nzContentParams: {
        marks: { 1: 'M1', 2: 'M2', 3: 'M3' },
        selectedMark: this.selectedMark
      }
    });

    drawerRef.afterClose.subscribe(data => {
      console.log(data);
    });

    drawerRef.afterOpen.subscribe(() => {
      console.log('Drawer Opened.');
    });
  }
}

Когда я динамически обновляю метки, компоновка не отображается должным образом, и я получаю это: enter image description here

Этовсе еще принимает старый объект.Как заставить приложение корректно выполнить рендеринг?

Большое спасибо.

1 Ответ

0 голосов
/ 30 ноября 2018

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

...