Heim > Artikel > Web-Frontend > So implementieren Sie die Drag-and-Drop-Funktion in AngularJS
In diesem Artikel wird hauptsächlich die von AngularJS implementierte einfache Drag-and-Drop-Funktion vorgestellt, die Implementierungstechniken im Zusammenhang mit der AngularJS-Ereignisreaktion und der dynamischen Bedienung von Seitenelementattributen umfasst.
Das Beispiel hierfür Der Artikel beschreibt die Implementierung der einfachen Drag-and-Drop-Funktionalität von AngularJS. Ich teile es Ihnen als Referenz mit:
<!DOCTYPE html> <html ng-app="myApp"> <head> <meta charset="UTF-8"> <title>www.jb51.net AngularJS拖拽</title> <style> *{ padding:0; margin:0; } .wei{ width:100px; height:100px; background: red; position:absolute; cursor: pointer; /*left:0;top:0;*/ } </style> </head> <body ng-controller="show"> <p class="wei" wei-yi data="true"></p> <p class="wei" wei-yi data="false"></p> <script src="jquery.js" type="text/javascript" charset="utf-8"></script> <script src="angular.min.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> var app = angular.module('myApp',[]); //自定义属性 app.directive("weiYi",function(){ return{ restrict :'A',//A属性,E标签,C类名,D注释 link :function(scope,element,attr){ attr.data=angular.equals(attr.data,"true"); //console.log(attr.data); console.log(element); element.on("mousedown",function(e){ var that = $(this); console.log(attr.data); if(attr.data){ $p=$("<p>"); console.log($p); $p.css({"width":"100px","height":"100px","border": "2px dotted green","position":"absolute","left":that.offset().left,"top":that.offset().top}); $p.appendTo($("body")); } var x=e.clientX-$(this).offset().left; var y=e.clientY-$(this).offset().top; //console.log(x+":"+y); $(document).on("mousemove",function(e){ if(attr.data){ $p.css({"left":e.clientX-x,"top":e.clientY-y}); }else{ that.css({"left":e.clientX-x,"top":e.clientY-y}); } }); $(document).on("mouseup",function(e){ //console.log($p); $(document).off(); if(attr.data){ that.css({"left":$p.offset().left,"top":$p.offset().top}); $p.remove(); } }) }) } } }); app.controller('show',['$scope',function(scope$){ }]); </script> </body> </html>
Der Betriebseffekt ist wie folgt:
Das Obige ist das, was ich zusammengestellt habe Ich hoffe, es wird Ihnen in Zukunft weiterhelfen.
Verwandte Artikel:
Detaillierte Interpretation des React Native Flexbox-Layouts
Welche Methoden gibt es für Referenzpfade in Vue-Einzeldateien?
Verwenden Sie Koa, um Projekte über Node.js zu erstellen
Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Drag-and-Drop-Funktion in AngularJS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!