![](/img/trans.png)
[英]How can I set a css “:hover” on a DOM created element in JavaScript?
[英]How to Set Angular Directive to the DOM element created in Javascript
我有一個指令,允許拖放Dom元素,即:
JS:
angular.module('animationApp').directive('myDraggable', ['$document', function($document){return{link: function(scope, element, attr) {
var startX = 0, startY = 0, x = 0, y = 0;
console.log("In myDraggable directive code");
element.css({
position: 'relative',
cursor: 'pointer'
});
element.on('mousedown', function(event) {
// Prevent default dragging of selected content
event.preventDefault();
startX = event.pageX - x;
startY = event.pageY - y;
$document.on('mousemove', mousemove);
$document.on('mouseup', mouseup);
});
function mousemove(event) {
y = event.pageY - startY;
x = event.pageX - startX;
element.css({
top: y + 'px',
left: x + 'px'
});
}
function mouseup() {
$document.off('mousemove', mousemove);
$document.off('mouseup', mouseup);
}
}};}]);
現在,我可以使用它,並且當我在HTML頁面上創建DOM元素並分配特定指令時,它可以很好地工作(拖放功能)。 喜歡 ,
HTML:
<div my-draggable = "">Hello</div>
<div my-draggable = "">Sid</div>
問題是,我無法將指令分配給我在Javascript代碼中創建的那些元素。 喜歡,
JS:
var tempView = document.getElementById('ngView');
var div = document.createElement("div");
var t = document.createTextNode("This is a paragraph.");
div.appendChild(t);
div.setAttribute("my-draggable","");
tempView.appendChild(div);
該指令在這種情況下不起作用!
問題是什么 ?
我做錯了什么 ?
謝謝!
您不能僅將指令添加為HTML節點。 因為這樣,您將jquery / javascript與AngularJS混合使用。 當您添加新元素時,AngularJS無法知道已添加該元素。 您可以使用$ compile服務來編譯HTML元素,以便AngularJS實際執行您的指令。
請參見: AngularJS中的動態添加指令
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.