-5

getSelection = () => {
  console.log("this", this); //valid but empty json
  console.log("this.parentNode", this.parentNode); //<=undefined
}
document.querySelector('i.edit').addEventListener('click', getSelection, false);
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<div class="control-group">
  <label for="name" class="control-label">
          <p class="text-info">Alex<i class="icon-star"></i> </p>
        </label>
  <input type="text" class="edit-input" />
  <i class="fa fa-pencil edit" aria-hidden="true"></i>
</div>
mplungjan
  • 169,008
  • 28
  • 173
  • 236
ishandutta2007
  • 16,676
  • 16
  • 93
  • 129

1 Answers1

3

As you use an arrow function, your this doesn't refer to the object.

Use the event.target property

    <div class="control-group">
      <label for="name" class="control-label">
              <p class="text-info">Alex<i class="icon-star"></i> </p>
            </label>
      <input type="text" class="edit-input" />
      <i class="fa fa-pencil edit" aria-hidden="true">edit</i>
    </div>

    <script>
      getSelection = (e) => {
        //console.log("this", this); //valid but empty json
        console.log("e.target.parentNode", e.target.parentNode); //<=undefined
      }
      document.querySelector('i.edit').addEventListener('click', getSelection, false);
    </script>
Asons
  • 84,923
  • 12
  • 110
  • 165