Search code examples
svgiconsclickable

Many svg's near with each other as clickable icons


I have many icons svg, I could use them as fonts if that is helpful and I would like to use ng-click(basically any kinda of click you know) the way that when i click on svg1 and svg2 wont be clicked. Till now i have tried allot of icons and many ways of doing it without success. I have upload to codepen small example, each region of that country have it's own svg which cover other svg's and make click on them impossible. Basic use of svg is below:

<svg>
    <use xlink:href="#icon-region"></use>
</svg>

Solution

  • Since all <svg> elements in your page are absolute positioned and have both width and height of 100%, it's possible to only catch elements from the last element. That behavior comes from the way elements are rendered, within layers, like the example bellow:

    +-<svg>--+
    |+-<svg>--+
    ||+-<svg>--+
    |||        |
    +||        |
     +|        |
      +--------+
    

    If all those elements have the same width, height and position you can only catch events from the last one, on the top of all.

    To avoid this behavior you can do the following, with CSS:

    .regionPosition {
      position: absolute;
      top: 0px;
      left: 0px;
      width: 100%;
      height: 100%;
      pointer-events: none;
    }
    
    .regionPosition > * {
      pointer-events: all;
    }
    

    This way you disable the event listening from <svg> elements – with regionPosition class – and catch only the events from their immediate children.

    Since you're using <use> inside your SVG to get the actually graphics, you can't rely only on Angular to bind the event, because the elements are not yet there when you load the script. You'll need to attach the event listener to the document and then check the target before call the function you want. This can be easily done with jQuery, as follows:

    jQuery(document).on('click', '.regionPosition > *', function () {
      // Call your function.
    });
    

    I changed your code a bit to show how to do it, here: http://codepen.io/anon/pen/waLwrm. I'm using a simple window.console.log() call to just log the clicked element. You can change it to another logic in your final code.

    Reference: jQuery hover problem due to z-index