Angular $ compile指令不更新DOM对象

时间:2013-06-28 15:46:51

标签: javascript angularjs d3.js angularjs-directive

我正在尝试将AngularJS和D3集成到一个允许您绘制,拖动和调整形状大小的应用程序中。我正在尝试使用angular绑定属性以避免必须手动更新DOM,但它无法正常工作。

我有以下代码来创建一个矩形。基本上,我使用transform属性创建一个SVG group对象,该属性应绑定到范围变量。然后我将rect附加到该组:

var drawSquare = function () {
    console.log("DrawSquare");
    var id = uuid.v4();
    scope.objects[id] = { x: 0, y: 0, w: 40, h: 40 };
    var parent = d3.select(document.createElementNS("http://www.w3.org/2000/svg", "g"))
        .attr("id", id)
        .attr("transform", "translate({{objects['" + id + "'].x}}, {{objects['" + id + "'].y}})");

    var element = parent.data([scope.objects[id]])
        .append("rect")
        .call(drag)
        .call(click);

    setSquareAttrs(element, id);
    //.attr(defaultSquare);
    console.log("parent", parent.node());
    $compile(parent.node())(scope);
    console.log("parent", parent.node());

    container.node().appendChild(parent.node());
};

我创建了SVG group元素,使用Angular进行编译,然后将其附加到DOM。我的拖动处理程序更新了DOM对象应绑定到的scope中的Angular对象。

我的拖动处理程序如下:

// Main drag function.
var drag = d3.behavior.drag()
    .on("drag", function (d) {
        console.log("dragmove!", d3.event.x, d3.event.y);
        var id = d3.select(this.parentNode).attr("id");
        console.log("id", id);
        console.log("scopeobjects", scope.objects[id]);
        scope.objects[id].x = d3.event.x;
        scope.objects[id].y = d3.event.y;
    });

当我在控制台中记录我的范围对象时,我可以看到它正在更新。但是,我的transform元素上的group属性停留在0,0。有人看到任何明显错误吗?在Angular插值绑定似乎没有更新之前,有没有人遇到过这样的情况?

谢谢。

1 个答案:

答案 0 :(得分:3)

我的开发团队帮我找到了答案。为了更新绑定,有必要调用$scope.$apply$scope.$digest。这通知Angular某些内容已发生变化,Angular将更新其所有内插绑定。显然,变化跟踪不会在Angular指令中自动发生。

新代码如下所示:

// Main drag function.
var drag = d3.behavior.drag()
    .on("drag", function (d) {
        console.log("dragmove!", d3.event.x, d3.event.y);
        var id = d3.select(this.parentNode).attr("id");
        console.log("id", id);
        console.log("scopeobjects", scope.objects[id]);
        scope.$apply(function () { // This wraps the changes.
            scope.objects[id].x = d3.event.x;
            scope.objects[id].y = d3.event.y;
        }
    });

translate属性现在可以正确更新。