Git Product home page Git Product logo

drag-drop-repro's Introduction

Angular CDK drag-and-drop problem repro

This repository reproduces a problem with the Angular CDK drag-and-drop module.

I expected all three cards to have working drag-and-drop lists that allow the user to reorder the same underlying words list.

In fact, the middle one does not work, because it is generated by a *ngFor over the result of a method on the component. Trying to drag and drop words in this card simply does not do anything; there is no compile error, or any error or warning on the JavaScript console.

This was raised as the following issue in the angular/components project: angular/components#21682

There, it emerged that this is not in fact a drag-and-drop bug but a consequence of how Angular change detection works. As items are dragged in the middle card, change detection constantly fires, which causes the method to keep being re-evaluated. This destroys the item being dragged.

One solution I found (bottom card) was to use an Angular pipe. This works, provided the input array is not modified in place (pure pipes only trigger when their input values change from the point of view of referential equality).

This project was generated with Angular CLI version 11.1.1.

Development server

Run ng serve for a dev server. Navigate to http://localhost:4200/. The app will automatically reload if you change any of the source files.

Code scaffolding

Run ng generate component component-name to generate a new component. You can also use ng generate directive|pipe|service|class|guard|interface|enum|module.

Build

Run ng build to build the project. The build artifacts will be stored in the dist/ directory. Use the --prod flag for a production build.

Running unit tests

Run ng test to execute the unit tests via Karma.

Running end-to-end tests

Run ng e2e to execute the end-to-end tests via Protractor.

Further help

To get more help on the Angular CLI use ng help or go check out the Angular CLI Overview and Command Reference page.

drag-drop-repro's People

Contributors

amdw avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.