$location not working in AngularJS using d3.js

This is the first time I face the issue and can't figure out why. I'm using d3 to create an icicle chart. There is a click event that is firing and calling changePath(). I see the console log which means that I do have access to $location.path but when I try to set it nothing happens... not a new page not an error page nothing... If I don't change paths via angular my router won't maintain scope which is what I'm looking for... any clues?

var parentCtrl = function($scope,$location){

$scope.makeBSC = function(){

        var changePath = function(el){
          console.log($location.path());
          $location.path(el)
        }
        var width = 405,
            height = 420,
            color = d3.scale.category20c();

        var vis = d3.select("#bscChart").append("svg")
            .attr("width", height)
            .attr("height", width);

        var partition = d3.layout.partition()
            .size([width, height])
            .value(function(d) { return d.size; });

        var json = data;


        vis.data([json]).selectAll("rect")
          .data(partition.nodes)
            .enter().append("rect")
              .attr("y", function(d) { return d.x; })
              .attr("x", function(d) { return d.y; })
              .attr("height", function(d) { return d.dx; })
              .attr("width", function(d) { return d.dy; })
              .attr("class",function(d){
                if(d.isSel) return "rectBlue"
                return "rectGray"
              }).on("click", function(d){
                changePath(d.goTo);
         });
     }
}

OCD will not let me leave this question 'open'. So, as groner pointed out... Hi, I think you'll find the answer to your question in this question: AngularJS $location not changing the path

Also, a little value-ad. Checkout these directives that wrap d3 http://www.fullscale.co/dangle/

链接地址: http://www.djcxy.com/p/84196.html

上一篇: 如何在xAxis上使用d3.js格式化时间

下一篇: $ location在使用d3.js的AngularJS中不起作用