Angular7 - Material / CDK-Drag and Drop

Fitur Drag and Drop baru yang ditambahkan ke Angular 7 CDK membantu untuk menarik dan melepaskan elemen dari daftar. Kami akan memahami cara kerja Drag and Drop Module dengan bantuan sebuah contoh. Fitur tersebut ditambahkan ke cdk. Pertama-tama kita perlu mendownload dependensi seperti yang ditunjukkan di bawah ini -

npm install @angular/cdk --save

Setelah langkah di atas selesai. Mari kita impor modul drag and drop di app.module.ts seperti yang ditunjukkan di bawah ini -

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppRoutingModule , RoutingComponent} from './app-routing.module';
import { AppComponent } from './app.component';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
import { MyserviceService } from './myservice.service';
import { HttpClientModule } from '@angular/common/http';
import { ScrollDispatchModule } from '@angular/cdk/scrolling';
import { DragDropModule } from '@angular/cdk/drag-drop';

@NgModule({
   declarations: [
      SqrtPipe,
      AppComponent,
      NewCmpComponent,
      ChangeTextDirective,
      RoutingComponent
   ],
   imports: [
      BrowserModule,
      AppRoutingModule,
      HttpClientModule,
      ScrollDispatchModule,
      DragDropModule
   ],
   providers: [MyserviceService],
   bootstrap: [AppComponent]
})
export class AppModule { }

DragDropModule diimpor dari '@angular/cdk/drag-drop' dan modul ditambahkan ke array impor seperti yang ditunjukkan di atas.

Kami akan menggunakan detail dari api, (http://jsonplaceholder.typicode.com/users) untuk ditampilkan di layar. Kami memiliki layanan yang akan mengambil data dari api seperti yang ditunjukkan di bawah ini -

myservice.service.ts

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';

@Injectable({
   providedIn: 'root'
})
export class MyserviceService {
   private finaldata = [];
   private apiurl = "http://jsonplaceholder.typicode.com/users";
   constructor(private http: HttpClient) { }
   getData() {
      return this.http.get(this.apiurl);
   }
}

Setelah selesai, panggil layanan di dalam app.component.ts seperti yang ditunjukkan di bawah ini -

import { Component } from '@angular/core';
import { MyserviceService } from './myservice.service';

@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 7 Project!';
   public personaldetails = [];
   constructor(private myservice: MyserviceService) {}
   ngOnInit() {
      this.myservice.getData().subscribe((data) => {
         this.personaldetails = Array.from(Object.keys(data), k=>data[k]);
         console.log(this.personaldetails);
      });
   }
}

Kami memiliki data yang diperlukan tersedia dalam variabel detail pribadi. Sekarang mari kita gunakan yang sama untuk ditampilkan kepada pengguna seperti yang ditunjukkan di bawah ini -

<h3>Angular 7 - Drag and Drop Module</h3>
<div>
   <div *ngFor="let item of personaldetails; let i = index" class="divlayout”>
      {{item.name}}
   </div >
</div>

Kami telah menambahkan class = ”divlayout” dan detail kelas ada di app.component.css.

.divlayout{
   width: 40%;
   background-color: #ccc;
   margin-bottom: 5px;
   padding: 10px 10px;
   border: 3px solid #73AD21;
}

Layar berikut akan ditampilkan di browser -

Itu tidak akan menarik dan melepas apapun, kita perlu menambahkan properti dragdrop cdk di app.component.html seperti yang ditunjukkan di bawah ini -

<h3>Angular 7 - Drag and Drop Module</h3>
<div cdkDropList
   #personList = "cdkDropList"
   [cdkDropListData] = "personaldetails"
   [cdkDropListConnectedTo] = "[userlist]"
   class = "example-list"
   (cdkDropListDropped) = "onDrop($event)" >
   
   <div *ngFor = "let item of personaldetails; 
      let i = index" class = "divlayout" cdkDrag>
      {{item.name}}
   </div >
</div&t;

Yang disorot adalah semua properti yang diperlukan untuk melakukan seret dan lepas. Saat Anda memeriksa di browser, ini memungkinkan Anda untuk menyeret item. Ini tidak akan menjatuhkannya dalam daftar dan akan tetap seperti saat Anda meninggalkan penunjuk mouse.

Di sini memungkinkan untuk menyeret item dari daftar tetapi setelah Anda meninggalkan penunjuk mouse, itu akan pergi dan menetap di tempat yang sama. Untuk menambahkan fitur drop, kita perlu menambahkan event onDrop di app.component.ts seperti yang ditunjukkan di bawah ini -

Pertama kita harus mengimpor modul cdk dragdrap seperti yang ditunjukkan di bawah ini -

import {CdkDragDrop, moveItemInArray, transferArrayItem} 
from '@angular/cdk/drag-drop';

Berikut adalah kode lengkap di app.component.ts -

import { Component } from '@angular/core';
import { MyserviceService } from './myservice.service';
import {CdkDragDrop, moveItemInArray, transferArrayItem} from '@angular/cdk/drag-drop';

@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 7 Project!';
   public personaldetails = [];
   constructor(private myservice: MyserviceService) {}
   ngOnInit() {
      this.myservice.getData().subscribe((data) => {
         this.personaldetails = Array.from(Object.keys(data), 
         k=>data[k]);
         console.log(this.personaldetails);
      });
   }
   onDrop(event: CdkDragDrop<string[]>) {
      if (event.previousContainer === event.container) {
         moveItemInArray(event.container.data, 
            event.previousIndex, event.currentIndex);
      } else {
         transferArrayItem(event.previousContainer.data,
         event.container.data,
         event.previousIndex,
         event.currentIndex);
      }
   }
}

Fungsi onDrop menangani menjatuhkan item yang ditarik ke posisi yang diperlukan.

Itu memanfaatkan moveItemInArray dan transferArrayItem kami telah mengimpor dari modul dragdrop cdk.

Sekarang mari kita lihat demo lagi di browser -

Sekarang memungkinkan Anda untuk menarik dan melepas item dalam posisi yang diperlukan seperti yang ditunjukkan di atas. Fitur ini bekerja dengan sangat lancar tanpa masalah flicker dan dapat digunakan di aplikasi Anda di mana pun diperlukan.