D3.js Tree Expand All and Collapse All










7















I'm building a Tree using D3.js and what I am trying to do is add two buttons, Expand All and Collapse All to the top of the page like this.



Expand All and Collapse All in D3.js



When I click "Expand All", all the nodes should expand. And when I click "Collapse All", all the nodes should collapse to the root element.



Here's my current code http://bl.ocks.org/anonymous/ab8d7f85cca6f745a107



But the problem is, it isn't working. Can somebody suggest how to make it work?










share|improve this question


























    7















    I'm building a Tree using D3.js and what I am trying to do is add two buttons, Expand All and Collapse All to the top of the page like this.



    Expand All and Collapse All in D3.js



    When I click "Expand All", all the nodes should expand. And when I click "Collapse All", all the nodes should collapse to the root element.



    Here's my current code http://bl.ocks.org/anonymous/ab8d7f85cca6f745a107



    But the problem is, it isn't working. Can somebody suggest how to make it work?










    share|improve this question
























      7












      7








      7


      2






      I'm building a Tree using D3.js and what I am trying to do is add two buttons, Expand All and Collapse All to the top of the page like this.



      Expand All and Collapse All in D3.js



      When I click "Expand All", all the nodes should expand. And when I click "Collapse All", all the nodes should collapse to the root element.



      Here's my current code http://bl.ocks.org/anonymous/ab8d7f85cca6f745a107



      But the problem is, it isn't working. Can somebody suggest how to make it work?










      share|improve this question














      I'm building a Tree using D3.js and what I am trying to do is add two buttons, Expand All and Collapse All to the top of the page like this.



      Expand All and Collapse All in D3.js



      When I click "Expand All", all the nodes should expand. And when I click "Collapse All", all the nodes should collapse to the root element.



      Here's my current code http://bl.ocks.org/anonymous/ab8d7f85cca6f745a107



      But the problem is, it isn't working. Can somebody suggest how to make it work?







      javascript d3.js






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Feb 26 '15 at 22:46









      RonakRonak

      1912213




      1912213






















          3 Answers
          3






          active

          oldest

          votes


















          16














          Try this code. Here is the working JsFiddle.



          function expand(d) 
          var children = (d.children)?d.children:d._children;
          if (d._children)
          d.children = d._children;
          d._children = null;

          if(children)
          children.forEach(expand);


          function expandAll()
          expand(root);
          update(root);


          function collapseAll()
          root.children.forEach(collapse);
          collapse(root);
          update(root);






          share|improve this answer























          • Thanks for sharing

            – Musakkhir Sayyed
            Sep 1 '17 at 10:22


















          2














          just add this



           function collapse(d) 
          if (d.children)
          d._children = d.children;
          d._children.forEach(collapse);
          d.children = null;



          function expand(d)
          if (d._children)
          d.children = d._children;
          d.children.forEach(expand);
          d._children = null;




          $("#expand_button").click(function()
          source.children.forEach(expand);
          update(source);
          );


          $("#collapse_button").click(function()
          root.children.forEach(collapse);
          update(root);
          );





          share|improve this answer






























            0














            try this fiddle: http://jsfiddle.net/z9tmgpwd/



            function expand(d) 
            var children = (d.children) ? d.children : d._children;
            if (d._children)
            d.children = d._children;
            d._children = null;

            if (children) children.forEach(expand);


            function expandAll()
            expand(root);
            update(root);


            function collapseAll()
            root.children.forEach(collapse);
            collapse(root);
            update(root);

            var margin =
            top: 20,
            right: 120,
            bottom: 20,
            left: 120
            ,
            width = 960 - margin.right - margin.left,
            height = 800 - margin.top - margin.bottom;
            var i = 0,
            duration = 750,
            root;
            var tree = d3.layout.tree().size([height, width]);
            var diagonal = d3.svg.diagonal().projection(function (d)
            return [d.y, d.x];
            );
            var svg = d3.select("body").append("svg").attr("width", width + margin.right
            + margin.left).attr("height", height + margin.top +
            margin.bottom).append("g").attr("transform", "translate(" + margin.left +
            "," + margin.top + ")");
            var flare =
            "name": "flare",
            "children": [
            "name": "analytics",
            "children": [
            "name": "cluster",
            "children": [
            "name": "AgglomerativeCluster",
            "size": 3938
            ,
            "name": "CommunityStructure",
            "size": 3812
            ,
            "name": "HierarchicalCluster",
            "size": 6714
            ]
            ,
            "name": "graph",
            "children": [
            "name": "BetweennessCentrality",
            "size": 3534
            ,
            "name": "LinkDistance",
            "size": 5731
            ]
            ]
            ,
            "name": "animate",
            "children": [
            "name": "Easing",
            "size": 17010
            ,
            "name": "FunctionSequence",
            "size": 5842
            ,
            "name": "Transitioner",
            "size": 19975
            ,
            "name": "TransitionEvent",
            "size": 1116
            ,
            "name": "Tween",
            "size": 6006
            ]
            ]
            ;
            root = flare;
            root.x0 = height / 2;
            root.y0 = 0;

            function update(source)
            // Compute the new tree layout.
            var nodes = tree.nodes(root).reverse(),
            links = tree.links(nodes);
            // Normalize for fixed-depth.
            nodes.forEach(function (d)
            d.y = d.depth * 180;
            );
            // Update the nodes…
            var node = svg.selectAll("g.node").data(nodes, function (d)
            return d.id );
            // Enter any new nodes at the parent's previous position.
            var nodeEnter = node.enter().append("g").attr("class",
            "node").attr("transform", function (d)
            return "translate(" + source.y0 + "," + source.x0 + ")";
            ).on("click", click).on("mouseover", mouseover).on("mouseout", mouseout);
            nodeEnter.append("circle").attr("r", 1e-6).style("fill", function (d)
            return d._children ? "lightsteelblue" : "#fff";
            );
            nodeEnter.append("text").attr("x", function (d) d._children ? -10 : 10;
            ).attr("dy", ".35em").attr("text-anchor", function (d)
            return d.children ).text(function (d)
            return d.name;
            ).style("fill-opacity", 1e-6);
            // Transition nodes to their new position.
            var nodeUpdate = node.transition().duration(duration).attr("transform",
            function (d)
            return "translate(" + d.y + "," + d.x + ")";
            );
            nodeUpdate.select("circle").attr("r", 4.5).style("fill", function (d)
            return d._children ? "lightsteelblue" : "#fff";
            );
            nodeUpdate.select("text").style("fill-opacity", 1);
            // Transition exiting nodes to the parent's new position.
            var nodeExit = node.exit().transition().duration(duration).attr("transform",
            function (d)
            return "translate(" + source.y + "," + source.x + ")";
            ).remove();
            nodeExit.select("circle").attr("r", 1e-6);
            nodeExit.select("text").style("fill-opacity", 1e-6);
            // Update the links…
            var link = svg.selectAll("path.link").data(links, function (d)
            return d.target.id;
            );
            // Enter any new links at the parent's previous position.
            link.enter().insert("path", "g").attr("class", "link").attr("d", function
            (d)
            var o =
            x: source.x0,
            y: source.y0
            ;
            return diagonal(
            source: o,
            target: o
            );
            );
            // Transition links to their new position.
            link.transition().duration(duration).attr("d", diagonal);
            // Transition exiting nodes to the parent's new position.
            link.exit().transition().duration(duration).attr("d", function (d)
            var o =
            x: source.x,
            y: source.y
            ;
            return diagonal(
            source: o,
            target: o
            );
            ).remove();
            // Stash the old positions for transition.
            nodes.forEach(function (d)
            d.x0 = d.x;
            d.y0 = d.y;
            );

            // Toggle children on click.
            function click(d)
            if (d.children)
            d._children = d.children;
            d.children = null;
            else
            d.children = d._children;
            d._children = null;

            update(d);


            function mouseover(d)
            d3.select(this).append("text").attr("class", "hover").attr('transform',
            function (d)
            return 'translate(5, -10)';
            ).text(d.name + ": " + d.id);

            // Toggle children on click.
            function mouseout(d)
            d3.select(this).select("text.hover").remove();


            function collapse(d)
            if (d.children)
            d._children = d.children;
            d._children.forEach(collapse);
            d.children = null;


            update(root);
            d3.select(self.frameElement).style("height", "800px");





            share|improve this answer






















              Your Answer






              StackExchange.ifUsing("editor", function ()
              StackExchange.using("externalEditor", function ()
              StackExchange.using("snippets", function ()
              StackExchange.snippets.init();
              );
              );
              , "code-snippets");

              StackExchange.ready(function()
              var channelOptions =
              tags: "".split(" "),
              id: "1"
              ;
              initTagRenderer("".split(" "), "".split(" "), channelOptions);

              StackExchange.using("externalEditor", function()
              // Have to fire editor after snippets, if snippets enabled
              if (StackExchange.settings.snippets.snippetsEnabled)
              StackExchange.using("snippets", function()
              createEditor();
              );

              else
              createEditor();

              );

              function createEditor()
              StackExchange.prepareEditor(
              heartbeatType: 'answer',
              autoActivateHeartbeat: false,
              convertImagesToLinks: true,
              noModals: true,
              showLowRepImageUploadWarning: true,
              reputationToPostImages: 10,
              bindNavPrevention: true,
              postfix: "",
              imageUploader:
              brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
              contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
              allowUrls: true
              ,
              onDemand: true,
              discardSelector: ".discard-answer"
              ,immediatelyShowMarkdownHelp:true
              );



              );













              draft saved

              draft discarded


















              StackExchange.ready(
              function ()
              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f28754273%2fd3-js-tree-expand-all-and-collapse-all%23new-answer', 'question_page');

              );

              Post as a guest















              Required, but never shown

























              3 Answers
              3






              active

              oldest

              votes








              3 Answers
              3






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes









              16














              Try this code. Here is the working JsFiddle.



              function expand(d) 
              var children = (d.children)?d.children:d._children;
              if (d._children)
              d.children = d._children;
              d._children = null;

              if(children)
              children.forEach(expand);


              function expandAll()
              expand(root);
              update(root);


              function collapseAll()
              root.children.forEach(collapse);
              collapse(root);
              update(root);






              share|improve this answer























              • Thanks for sharing

                – Musakkhir Sayyed
                Sep 1 '17 at 10:22















              16














              Try this code. Here is the working JsFiddle.



              function expand(d) 
              var children = (d.children)?d.children:d._children;
              if (d._children)
              d.children = d._children;
              d._children = null;

              if(children)
              children.forEach(expand);


              function expandAll()
              expand(root);
              update(root);


              function collapseAll()
              root.children.forEach(collapse);
              collapse(root);
              update(root);






              share|improve this answer























              • Thanks for sharing

                – Musakkhir Sayyed
                Sep 1 '17 at 10:22













              16












              16








              16







              Try this code. Here is the working JsFiddle.



              function expand(d) 
              var children = (d.children)?d.children:d._children;
              if (d._children)
              d.children = d._children;
              d._children = null;

              if(children)
              children.forEach(expand);


              function expandAll()
              expand(root);
              update(root);


              function collapseAll()
              root.children.forEach(collapse);
              collapse(root);
              update(root);






              share|improve this answer













              Try this code. Here is the working JsFiddle.



              function expand(d) 
              var children = (d.children)?d.children:d._children;
              if (d._children)
              d.children = d._children;
              d._children = null;

              if(children)
              children.forEach(expand);


              function expandAll()
              expand(root);
              update(root);


              function collapseAll()
              root.children.forEach(collapse);
              collapse(root);
              update(root);







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered Feb 27 '15 at 5:18









              GilshaGilsha

              12.5k32643




              12.5k32643












              • Thanks for sharing

                – Musakkhir Sayyed
                Sep 1 '17 at 10:22

















              • Thanks for sharing

                – Musakkhir Sayyed
                Sep 1 '17 at 10:22
















              Thanks for sharing

              – Musakkhir Sayyed
              Sep 1 '17 at 10:22





              Thanks for sharing

              – Musakkhir Sayyed
              Sep 1 '17 at 10:22













              2














              just add this



               function collapse(d) 
              if (d.children)
              d._children = d.children;
              d._children.forEach(collapse);
              d.children = null;



              function expand(d)
              if (d._children)
              d.children = d._children;
              d.children.forEach(expand);
              d._children = null;




              $("#expand_button").click(function()
              source.children.forEach(expand);
              update(source);
              );


              $("#collapse_button").click(function()
              root.children.forEach(collapse);
              update(root);
              );





              share|improve this answer



























                2














                just add this



                 function collapse(d) 
                if (d.children)
                d._children = d.children;
                d._children.forEach(collapse);
                d.children = null;



                function expand(d)
                if (d._children)
                d.children = d._children;
                d.children.forEach(expand);
                d._children = null;




                $("#expand_button").click(function()
                source.children.forEach(expand);
                update(source);
                );


                $("#collapse_button").click(function()
                root.children.forEach(collapse);
                update(root);
                );





                share|improve this answer

























                  2












                  2








                  2







                  just add this



                   function collapse(d) 
                  if (d.children)
                  d._children = d.children;
                  d._children.forEach(collapse);
                  d.children = null;



                  function expand(d)
                  if (d._children)
                  d.children = d._children;
                  d.children.forEach(expand);
                  d._children = null;




                  $("#expand_button").click(function()
                  source.children.forEach(expand);
                  update(source);
                  );


                  $("#collapse_button").click(function()
                  root.children.forEach(collapse);
                  update(root);
                  );





                  share|improve this answer













                  just add this



                   function collapse(d) 
                  if (d.children)
                  d._children = d.children;
                  d._children.forEach(collapse);
                  d.children = null;



                  function expand(d)
                  if (d._children)
                  d.children = d._children;
                  d.children.forEach(expand);
                  d._children = null;




                  $("#expand_button").click(function()
                  source.children.forEach(expand);
                  update(source);
                  );


                  $("#collapse_button").click(function()
                  root.children.forEach(collapse);
                  update(root);
                  );






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered May 12 '15 at 7:54









                  knives22knives22

                  245213




                  245213





















                      0














                      try this fiddle: http://jsfiddle.net/z9tmgpwd/



                      function expand(d) 
                      var children = (d.children) ? d.children : d._children;
                      if (d._children)
                      d.children = d._children;
                      d._children = null;

                      if (children) children.forEach(expand);


                      function expandAll()
                      expand(root);
                      update(root);


                      function collapseAll()
                      root.children.forEach(collapse);
                      collapse(root);
                      update(root);

                      var margin =
                      top: 20,
                      right: 120,
                      bottom: 20,
                      left: 120
                      ,
                      width = 960 - margin.right - margin.left,
                      height = 800 - margin.top - margin.bottom;
                      var i = 0,
                      duration = 750,
                      root;
                      var tree = d3.layout.tree().size([height, width]);
                      var diagonal = d3.svg.diagonal().projection(function (d)
                      return [d.y, d.x];
                      );
                      var svg = d3.select("body").append("svg").attr("width", width + margin.right
                      + margin.left).attr("height", height + margin.top +
                      margin.bottom).append("g").attr("transform", "translate(" + margin.left +
                      "," + margin.top + ")");
                      var flare =
                      "name": "flare",
                      "children": [
                      "name": "analytics",
                      "children": [
                      "name": "cluster",
                      "children": [
                      "name": "AgglomerativeCluster",
                      "size": 3938
                      ,
                      "name": "CommunityStructure",
                      "size": 3812
                      ,
                      "name": "HierarchicalCluster",
                      "size": 6714
                      ]
                      ,
                      "name": "graph",
                      "children": [
                      "name": "BetweennessCentrality",
                      "size": 3534
                      ,
                      "name": "LinkDistance",
                      "size": 5731
                      ]
                      ]
                      ,
                      "name": "animate",
                      "children": [
                      "name": "Easing",
                      "size": 17010
                      ,
                      "name": "FunctionSequence",
                      "size": 5842
                      ,
                      "name": "Transitioner",
                      "size": 19975
                      ,
                      "name": "TransitionEvent",
                      "size": 1116
                      ,
                      "name": "Tween",
                      "size": 6006
                      ]
                      ]
                      ;
                      root = flare;
                      root.x0 = height / 2;
                      root.y0 = 0;

                      function update(source)
                      // Compute the new tree layout.
                      var nodes = tree.nodes(root).reverse(),
                      links = tree.links(nodes);
                      // Normalize for fixed-depth.
                      nodes.forEach(function (d)
                      d.y = d.depth * 180;
                      );
                      // Update the nodes…
                      var node = svg.selectAll("g.node").data(nodes, function (d)
                      return d.id );
                      // Enter any new nodes at the parent's previous position.
                      var nodeEnter = node.enter().append("g").attr("class",
                      "node").attr("transform", function (d)
                      return "translate(" + source.y0 + "," + source.x0 + ")";
                      ).on("click", click).on("mouseover", mouseover).on("mouseout", mouseout);
                      nodeEnter.append("circle").attr("r", 1e-6).style("fill", function (d)
                      return d._children ? "lightsteelblue" : "#fff";
                      );
                      nodeEnter.append("text").attr("x", function (d) d._children ? -10 : 10;
                      ).attr("dy", ".35em").attr("text-anchor", function (d)
                      return d.children ).text(function (d)
                      return d.name;
                      ).style("fill-opacity", 1e-6);
                      // Transition nodes to their new position.
                      var nodeUpdate = node.transition().duration(duration).attr("transform",
                      function (d)
                      return "translate(" + d.y + "," + d.x + ")";
                      );
                      nodeUpdate.select("circle").attr("r", 4.5).style("fill", function (d)
                      return d._children ? "lightsteelblue" : "#fff";
                      );
                      nodeUpdate.select("text").style("fill-opacity", 1);
                      // Transition exiting nodes to the parent's new position.
                      var nodeExit = node.exit().transition().duration(duration).attr("transform",
                      function (d)
                      return "translate(" + source.y + "," + source.x + ")";
                      ).remove();
                      nodeExit.select("circle").attr("r", 1e-6);
                      nodeExit.select("text").style("fill-opacity", 1e-6);
                      // Update the links…
                      var link = svg.selectAll("path.link").data(links, function (d)
                      return d.target.id;
                      );
                      // Enter any new links at the parent's previous position.
                      link.enter().insert("path", "g").attr("class", "link").attr("d", function
                      (d)
                      var o =
                      x: source.x0,
                      y: source.y0
                      ;
                      return diagonal(
                      source: o,
                      target: o
                      );
                      );
                      // Transition links to their new position.
                      link.transition().duration(duration).attr("d", diagonal);
                      // Transition exiting nodes to the parent's new position.
                      link.exit().transition().duration(duration).attr("d", function (d)
                      var o =
                      x: source.x,
                      y: source.y
                      ;
                      return diagonal(
                      source: o,
                      target: o
                      );
                      ).remove();
                      // Stash the old positions for transition.
                      nodes.forEach(function (d)
                      d.x0 = d.x;
                      d.y0 = d.y;
                      );

                      // Toggle children on click.
                      function click(d)
                      if (d.children)
                      d._children = d.children;
                      d.children = null;
                      else
                      d.children = d._children;
                      d._children = null;

                      update(d);


                      function mouseover(d)
                      d3.select(this).append("text").attr("class", "hover").attr('transform',
                      function (d)
                      return 'translate(5, -10)';
                      ).text(d.name + ": " + d.id);

                      // Toggle children on click.
                      function mouseout(d)
                      d3.select(this).select("text.hover").remove();


                      function collapse(d)
                      if (d.children)
                      d._children = d.children;
                      d._children.forEach(collapse);
                      d.children = null;


                      update(root);
                      d3.select(self.frameElement).style("height", "800px");





                      share|improve this answer



























                        0














                        try this fiddle: http://jsfiddle.net/z9tmgpwd/



                        function expand(d) 
                        var children = (d.children) ? d.children : d._children;
                        if (d._children)
                        d.children = d._children;
                        d._children = null;

                        if (children) children.forEach(expand);


                        function expandAll()
                        expand(root);
                        update(root);


                        function collapseAll()
                        root.children.forEach(collapse);
                        collapse(root);
                        update(root);

                        var margin =
                        top: 20,
                        right: 120,
                        bottom: 20,
                        left: 120
                        ,
                        width = 960 - margin.right - margin.left,
                        height = 800 - margin.top - margin.bottom;
                        var i = 0,
                        duration = 750,
                        root;
                        var tree = d3.layout.tree().size([height, width]);
                        var diagonal = d3.svg.diagonal().projection(function (d)
                        return [d.y, d.x];
                        );
                        var svg = d3.select("body").append("svg").attr("width", width + margin.right
                        + margin.left).attr("height", height + margin.top +
                        margin.bottom).append("g").attr("transform", "translate(" + margin.left +
                        "," + margin.top + ")");
                        var flare =
                        "name": "flare",
                        "children": [
                        "name": "analytics",
                        "children": [
                        "name": "cluster",
                        "children": [
                        "name": "AgglomerativeCluster",
                        "size": 3938
                        ,
                        "name": "CommunityStructure",
                        "size": 3812
                        ,
                        "name": "HierarchicalCluster",
                        "size": 6714
                        ]
                        ,
                        "name": "graph",
                        "children": [
                        "name": "BetweennessCentrality",
                        "size": 3534
                        ,
                        "name": "LinkDistance",
                        "size": 5731
                        ]
                        ]
                        ,
                        "name": "animate",
                        "children": [
                        "name": "Easing",
                        "size": 17010
                        ,
                        "name": "FunctionSequence",
                        "size": 5842
                        ,
                        "name": "Transitioner",
                        "size": 19975
                        ,
                        "name": "TransitionEvent",
                        "size": 1116
                        ,
                        "name": "Tween",
                        "size": 6006
                        ]
                        ]
                        ;
                        root = flare;
                        root.x0 = height / 2;
                        root.y0 = 0;

                        function update(source)
                        // Compute the new tree layout.
                        var nodes = tree.nodes(root).reverse(),
                        links = tree.links(nodes);
                        // Normalize for fixed-depth.
                        nodes.forEach(function (d)
                        d.y = d.depth * 180;
                        );
                        // Update the nodes…
                        var node = svg.selectAll("g.node").data(nodes, function (d)
                        return d.id );
                        // Enter any new nodes at the parent's previous position.
                        var nodeEnter = node.enter().append("g").attr("class",
                        "node").attr("transform", function (d)
                        return "translate(" + source.y0 + "," + source.x0 + ")";
                        ).on("click", click).on("mouseover", mouseover).on("mouseout", mouseout);
                        nodeEnter.append("circle").attr("r", 1e-6).style("fill", function (d)
                        return d._children ? "lightsteelblue" : "#fff";
                        );
                        nodeEnter.append("text").attr("x", function (d) d._children ? -10 : 10;
                        ).attr("dy", ".35em").attr("text-anchor", function (d)
                        return d.children ).text(function (d)
                        return d.name;
                        ).style("fill-opacity", 1e-6);
                        // Transition nodes to their new position.
                        var nodeUpdate = node.transition().duration(duration).attr("transform",
                        function (d)
                        return "translate(" + d.y + "," + d.x + ")";
                        );
                        nodeUpdate.select("circle").attr("r", 4.5).style("fill", function (d)
                        return d._children ? "lightsteelblue" : "#fff";
                        );
                        nodeUpdate.select("text").style("fill-opacity", 1);
                        // Transition exiting nodes to the parent's new position.
                        var nodeExit = node.exit().transition().duration(duration).attr("transform",
                        function (d)
                        return "translate(" + source.y + "," + source.x + ")";
                        ).remove();
                        nodeExit.select("circle").attr("r", 1e-6);
                        nodeExit.select("text").style("fill-opacity", 1e-6);
                        // Update the links…
                        var link = svg.selectAll("path.link").data(links, function (d)
                        return d.target.id;
                        );
                        // Enter any new links at the parent's previous position.
                        link.enter().insert("path", "g").attr("class", "link").attr("d", function
                        (d)
                        var o =
                        x: source.x0,
                        y: source.y0
                        ;
                        return diagonal(
                        source: o,
                        target: o
                        );
                        );
                        // Transition links to their new position.
                        link.transition().duration(duration).attr("d", diagonal);
                        // Transition exiting nodes to the parent's new position.
                        link.exit().transition().duration(duration).attr("d", function (d)
                        var o =
                        x: source.x,
                        y: source.y
                        ;
                        return diagonal(
                        source: o,
                        target: o
                        );
                        ).remove();
                        // Stash the old positions for transition.
                        nodes.forEach(function (d)
                        d.x0 = d.x;
                        d.y0 = d.y;
                        );

                        // Toggle children on click.
                        function click(d)
                        if (d.children)
                        d._children = d.children;
                        d.children = null;
                        else
                        d.children = d._children;
                        d._children = null;

                        update(d);


                        function mouseover(d)
                        d3.select(this).append("text").attr("class", "hover").attr('transform',
                        function (d)
                        return 'translate(5, -10)';
                        ).text(d.name + ": " + d.id);

                        // Toggle children on click.
                        function mouseout(d)
                        d3.select(this).select("text.hover").remove();


                        function collapse(d)
                        if (d.children)
                        d._children = d.children;
                        d._children.forEach(collapse);
                        d.children = null;


                        update(root);
                        d3.select(self.frameElement).style("height", "800px");





                        share|improve this answer

























                          0












                          0








                          0







                          try this fiddle: http://jsfiddle.net/z9tmgpwd/



                          function expand(d) 
                          var children = (d.children) ? d.children : d._children;
                          if (d._children)
                          d.children = d._children;
                          d._children = null;

                          if (children) children.forEach(expand);


                          function expandAll()
                          expand(root);
                          update(root);


                          function collapseAll()
                          root.children.forEach(collapse);
                          collapse(root);
                          update(root);

                          var margin =
                          top: 20,
                          right: 120,
                          bottom: 20,
                          left: 120
                          ,
                          width = 960 - margin.right - margin.left,
                          height = 800 - margin.top - margin.bottom;
                          var i = 0,
                          duration = 750,
                          root;
                          var tree = d3.layout.tree().size([height, width]);
                          var diagonal = d3.svg.diagonal().projection(function (d)
                          return [d.y, d.x];
                          );
                          var svg = d3.select("body").append("svg").attr("width", width + margin.right
                          + margin.left).attr("height", height + margin.top +
                          margin.bottom).append("g").attr("transform", "translate(" + margin.left +
                          "," + margin.top + ")");
                          var flare =
                          "name": "flare",
                          "children": [
                          "name": "analytics",
                          "children": [
                          "name": "cluster",
                          "children": [
                          "name": "AgglomerativeCluster",
                          "size": 3938
                          ,
                          "name": "CommunityStructure",
                          "size": 3812
                          ,
                          "name": "HierarchicalCluster",
                          "size": 6714
                          ]
                          ,
                          "name": "graph",
                          "children": [
                          "name": "BetweennessCentrality",
                          "size": 3534
                          ,
                          "name": "LinkDistance",
                          "size": 5731
                          ]
                          ]
                          ,
                          "name": "animate",
                          "children": [
                          "name": "Easing",
                          "size": 17010
                          ,
                          "name": "FunctionSequence",
                          "size": 5842
                          ,
                          "name": "Transitioner",
                          "size": 19975
                          ,
                          "name": "TransitionEvent",
                          "size": 1116
                          ,
                          "name": "Tween",
                          "size": 6006
                          ]
                          ]
                          ;
                          root = flare;
                          root.x0 = height / 2;
                          root.y0 = 0;

                          function update(source)
                          // Compute the new tree layout.
                          var nodes = tree.nodes(root).reverse(),
                          links = tree.links(nodes);
                          // Normalize for fixed-depth.
                          nodes.forEach(function (d)
                          d.y = d.depth * 180;
                          );
                          // Update the nodes…
                          var node = svg.selectAll("g.node").data(nodes, function (d)
                          return d.id );
                          // Enter any new nodes at the parent's previous position.
                          var nodeEnter = node.enter().append("g").attr("class",
                          "node").attr("transform", function (d)
                          return "translate(" + source.y0 + "," + source.x0 + ")";
                          ).on("click", click).on("mouseover", mouseover).on("mouseout", mouseout);
                          nodeEnter.append("circle").attr("r", 1e-6).style("fill", function (d)
                          return d._children ? "lightsteelblue" : "#fff";
                          );
                          nodeEnter.append("text").attr("x", function (d) d._children ? -10 : 10;
                          ).attr("dy", ".35em").attr("text-anchor", function (d)
                          return d.children ).text(function (d)
                          return d.name;
                          ).style("fill-opacity", 1e-6);
                          // Transition nodes to their new position.
                          var nodeUpdate = node.transition().duration(duration).attr("transform",
                          function (d)
                          return "translate(" + d.y + "," + d.x + ")";
                          );
                          nodeUpdate.select("circle").attr("r", 4.5).style("fill", function (d)
                          return d._children ? "lightsteelblue" : "#fff";
                          );
                          nodeUpdate.select("text").style("fill-opacity", 1);
                          // Transition exiting nodes to the parent's new position.
                          var nodeExit = node.exit().transition().duration(duration).attr("transform",
                          function (d)
                          return "translate(" + source.y + "," + source.x + ")";
                          ).remove();
                          nodeExit.select("circle").attr("r", 1e-6);
                          nodeExit.select("text").style("fill-opacity", 1e-6);
                          // Update the links…
                          var link = svg.selectAll("path.link").data(links, function (d)
                          return d.target.id;
                          );
                          // Enter any new links at the parent's previous position.
                          link.enter().insert("path", "g").attr("class", "link").attr("d", function
                          (d)
                          var o =
                          x: source.x0,
                          y: source.y0
                          ;
                          return diagonal(
                          source: o,
                          target: o
                          );
                          );
                          // Transition links to their new position.
                          link.transition().duration(duration).attr("d", diagonal);
                          // Transition exiting nodes to the parent's new position.
                          link.exit().transition().duration(duration).attr("d", function (d)
                          var o =
                          x: source.x,
                          y: source.y
                          ;
                          return diagonal(
                          source: o,
                          target: o
                          );
                          ).remove();
                          // Stash the old positions for transition.
                          nodes.forEach(function (d)
                          d.x0 = d.x;
                          d.y0 = d.y;
                          );

                          // Toggle children on click.
                          function click(d)
                          if (d.children)
                          d._children = d.children;
                          d.children = null;
                          else
                          d.children = d._children;
                          d._children = null;

                          update(d);


                          function mouseover(d)
                          d3.select(this).append("text").attr("class", "hover").attr('transform',
                          function (d)
                          return 'translate(5, -10)';
                          ).text(d.name + ": " + d.id);

                          // Toggle children on click.
                          function mouseout(d)
                          d3.select(this).select("text.hover").remove();


                          function collapse(d)
                          if (d.children)
                          d._children = d.children;
                          d._children.forEach(collapse);
                          d.children = null;


                          update(root);
                          d3.select(self.frameElement).style("height", "800px");





                          share|improve this answer













                          try this fiddle: http://jsfiddle.net/z9tmgpwd/



                          function expand(d) 
                          var children = (d.children) ? d.children : d._children;
                          if (d._children)
                          d.children = d._children;
                          d._children = null;

                          if (children) children.forEach(expand);


                          function expandAll()
                          expand(root);
                          update(root);


                          function collapseAll()
                          root.children.forEach(collapse);
                          collapse(root);
                          update(root);

                          var margin =
                          top: 20,
                          right: 120,
                          bottom: 20,
                          left: 120
                          ,
                          width = 960 - margin.right - margin.left,
                          height = 800 - margin.top - margin.bottom;
                          var i = 0,
                          duration = 750,
                          root;
                          var tree = d3.layout.tree().size([height, width]);
                          var diagonal = d3.svg.diagonal().projection(function (d)
                          return [d.y, d.x];
                          );
                          var svg = d3.select("body").append("svg").attr("width", width + margin.right
                          + margin.left).attr("height", height + margin.top +
                          margin.bottom).append("g").attr("transform", "translate(" + margin.left +
                          "," + margin.top + ")");
                          var flare =
                          "name": "flare",
                          "children": [
                          "name": "analytics",
                          "children": [
                          "name": "cluster",
                          "children": [
                          "name": "AgglomerativeCluster",
                          "size": 3938
                          ,
                          "name": "CommunityStructure",
                          "size": 3812
                          ,
                          "name": "HierarchicalCluster",
                          "size": 6714
                          ]
                          ,
                          "name": "graph",
                          "children": [
                          "name": "BetweennessCentrality",
                          "size": 3534
                          ,
                          "name": "LinkDistance",
                          "size": 5731
                          ]
                          ]
                          ,
                          "name": "animate",
                          "children": [
                          "name": "Easing",
                          "size": 17010
                          ,
                          "name": "FunctionSequence",
                          "size": 5842
                          ,
                          "name": "Transitioner",
                          "size": 19975
                          ,
                          "name": "TransitionEvent",
                          "size": 1116
                          ,
                          "name": "Tween",
                          "size": 6006
                          ]
                          ]
                          ;
                          root = flare;
                          root.x0 = height / 2;
                          root.y0 = 0;

                          function update(source)
                          // Compute the new tree layout.
                          var nodes = tree.nodes(root).reverse(),
                          links = tree.links(nodes);
                          // Normalize for fixed-depth.
                          nodes.forEach(function (d)
                          d.y = d.depth * 180;
                          );
                          // Update the nodes…
                          var node = svg.selectAll("g.node").data(nodes, function (d)
                          return d.id );
                          // Enter any new nodes at the parent's previous position.
                          var nodeEnter = node.enter().append("g").attr("class",
                          "node").attr("transform", function (d)
                          return "translate(" + source.y0 + "," + source.x0 + ")";
                          ).on("click", click).on("mouseover", mouseover).on("mouseout", mouseout);
                          nodeEnter.append("circle").attr("r", 1e-6).style("fill", function (d)
                          return d._children ? "lightsteelblue" : "#fff";
                          );
                          nodeEnter.append("text").attr("x", function (d) d._children ? -10 : 10;
                          ).attr("dy", ".35em").attr("text-anchor", function (d)
                          return d.children ).text(function (d)
                          return d.name;
                          ).style("fill-opacity", 1e-6);
                          // Transition nodes to their new position.
                          var nodeUpdate = node.transition().duration(duration).attr("transform",
                          function (d)
                          return "translate(" + d.y + "," + d.x + ")";
                          );
                          nodeUpdate.select("circle").attr("r", 4.5).style("fill", function (d)
                          return d._children ? "lightsteelblue" : "#fff";
                          );
                          nodeUpdate.select("text").style("fill-opacity", 1);
                          // Transition exiting nodes to the parent's new position.
                          var nodeExit = node.exit().transition().duration(duration).attr("transform",
                          function (d)
                          return "translate(" + source.y + "," + source.x + ")";
                          ).remove();
                          nodeExit.select("circle").attr("r", 1e-6);
                          nodeExit.select("text").style("fill-opacity", 1e-6);
                          // Update the links…
                          var link = svg.selectAll("path.link").data(links, function (d)
                          return d.target.id;
                          );
                          // Enter any new links at the parent's previous position.
                          link.enter().insert("path", "g").attr("class", "link").attr("d", function
                          (d)
                          var o =
                          x: source.x0,
                          y: source.y0
                          ;
                          return diagonal(
                          source: o,
                          target: o
                          );
                          );
                          // Transition links to their new position.
                          link.transition().duration(duration).attr("d", diagonal);
                          // Transition exiting nodes to the parent's new position.
                          link.exit().transition().duration(duration).attr("d", function (d)
                          var o =
                          x: source.x,
                          y: source.y
                          ;
                          return diagonal(
                          source: o,
                          target: o
                          );
                          ).remove();
                          // Stash the old positions for transition.
                          nodes.forEach(function (d)
                          d.x0 = d.x;
                          d.y0 = d.y;
                          );

                          // Toggle children on click.
                          function click(d)
                          if (d.children)
                          d._children = d.children;
                          d.children = null;
                          else
                          d.children = d._children;
                          d._children = null;

                          update(d);


                          function mouseover(d)
                          d3.select(this).append("text").attr("class", "hover").attr('transform',
                          function (d)
                          return 'translate(5, -10)';
                          ).text(d.name + ": " + d.id);

                          // Toggle children on click.
                          function mouseout(d)
                          d3.select(this).select("text.hover").remove();


                          function collapse(d)
                          if (d.children)
                          d._children = d.children;
                          d._children.forEach(collapse);
                          d.children = null;


                          update(root);
                          d3.select(self.frameElement).style("height", "800px");






                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered Aug 15 '17 at 6:15









                          batmanbatman

                          11




                          11



























                              draft saved

                              draft discarded
















































                              Thanks for contributing an answer to Stack Overflow!


                              • Please be sure to answer the question. Provide details and share your research!

                              But avoid


                              • Asking for help, clarification, or responding to other answers.

                              • Making statements based on opinion; back them up with references or personal experience.

                              To learn more, see our tips on writing great answers.




                              draft saved


                              draft discarded














                              StackExchange.ready(
                              function ()
                              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f28754273%2fd3-js-tree-expand-all-and-collapse-all%23new-answer', 'question_page');

                              );

                              Post as a guest















                              Required, but never shown





















































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown

































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown







                              這個網誌中的熱門文章

                              How to read a connectionString WITH PROVIDER in .NET Core?

                              Node.js Script on GitHub Pages or Amazon S3

                              Museum of Modern and Contemporary Art of Trento and Rovereto