कोणीय 7 - सामग्री / सीडीके-ड्रैग एंड ड्रॉप

कोणीय 7 सीडीके में जोड़ा गया नया ड्रैग एंड ड्रॉप फीचर तत्वों को सूची से खींचने और छोड़ने में मदद करता है। हम एक उदाहरण की मदद से ड्रैग एंड ड्रॉप मॉड्यूल के काम को समझेंगे। Cdk में सुविधा जोड़ी जाती है। हमें पहले नीचे दी गई निर्भरता को डाउनलोड करने की आवश्यकता है -

npm install @angular/cdk --save

एक बार जब उपरोक्त कदम किया जाता है। हमें नीचे दिखाए अनुसार app.module.ts में ड्रैग और ड्रॉप मॉड्यूल आयात करें -

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 से आयात किया जाता है '@angular/cdk/drag-drop' और मॉड्यूल ऊपर दिखाए गए अनुसार सरणी आयात करने के लिए जोड़ा गया है।

हम स्क्रीन पर प्रदर्शित होने के लिए एपीआई (http://jsonplaceholder.typicode.com/users) के विवरण का उपयोग करेंगे । हमारे पास सेवा है जो नीचे दिखाए गए अनुसार एपीआई से डेटा प्राप्त करेगी -

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);
   }
}

एक बार app.component.ts के अंदर सेवा के रूप में नीचे दिखाया गया है -

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);
      });
   }
}

हमारे पास वैयक्तिकृत चर में उपलब्ध आवश्यक डेटा है। अब हम नीचे दिखाए गए अनुसार उपयोगकर्ता को प्रदर्शित करने के लिए उसी का उपयोग करते हैं -

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

हमने वर्ग = "divlayout" जोड़ा है और वर्ग का विवरण app.component.css में है।

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

निम्न स्क्रीन ब्राउज़र में प्रदर्शित होगी -

यह कुछ भी नहीं खींचेगा और छोड़ देगा, हमें नीचे दिखाए गए अनुसार app.component.html में ड्रैगड्रॉप cdk गुण जोड़ना होगा -

<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;

हाइलाइट किए गए सभी गुण खींचें और ड्रॉप करने के लिए आवश्यक हैं। जब आप ब्राउज़र में जांच करते हैं, तो यह आपको आइटम को खींचने की अनुमति देता है। यह सूची में इसे नहीं छोड़ेगा और जब आप माउस पॉइंटर छोड़ेंगे तो यह रहेगा।

यहां यह सूची से आइटम को खींचने की अनुमति देता है लेकिन एक बार जब आप माउस पॉइंटर को छोड़ देते हैं तो यह उसी स्थान पर जाकर बस जाएगा। ड्रॉप फीचर जोड़ने के लिए, हमें app.component.ts में इवेंट ऑनड्रॉप जोड़ने की आवश्यकता है जैसा कि नीचे दिखाया गया है -

सबसे पहले हमें ड्रैगड्रैप सीडीडी मॉड्यूल्स को आयात करना होगा जैसा कि नीचे दिखाया गया है -

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

यहाँ 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);
      }
   }
}

फ़ंक्शन ऑनड्रॉप आवश्यक स्थिति में खींचे गए आइटम को छोड़ने का ख्याल रखता है।

यह का उपयोग करता है moveItemInArray तथा transferArrayItem हमने cdk ड्रैगड्रॉप मॉड्यूल से आयात किया है।

अब हम ब्राउज़र में फिर से डेमो देखते हैं -

अब यह आपको आवश्यक स्थिति में आइटम को खींचने और छोड़ने की अनुमति देता है जैसा कि ऊपर दिखाया गया है। फीचर बिना किसी झिलमिलाहट के बहुत आसानी से काम करता है और जरूरत पड़ने पर आपके एप्लिकेशन में इसका उपयोग किया जा सकता है।