Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
  
  <h2>Title 1<span>show</span></h2>
  <p>Lorem 1 ipsum paragrafix maximus...</p>
  
  <h2>Title 2<span>show</span></h2>
  <p>Lorem 2 ipsum paragrafix maximus...</p> 
  <h2>Title 3<span>show</span></h2>
  <p>Lorem 3 ipsum paragrafix maximus...</p>
  
  
</body>
</html>
 
var h2 = document.querySelectorAll('h2');
function nextTo(el){ // Get next sibling element
  do{el=el.nextSibling;}while(el && el.nodeType!=1);
  return el;
}
function toggler(){ 
  
  var tog = this.io ^= 1; // ^ bw. XOR
  // console.log("Toggle set to: "+ tog); // test
  
  // Now that we have stored 1/0 state
  // into the this.io property
  // let's do some stuff using 'tog'
  this.children[0].innerHTML = tog ? "hide" : "show";
  nextTo(this).className     = tog ? "opened" : "";
}
// Click event listeners to all H2 elements
for(var i=0; i<h2.length; i++){
  h2[i].addEventListener('click', toggler, false);
}
Output 300px

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
anonymouspro
0viewers