A imagem não alterna entre oculto e exibido

Não consigo obter uma imagemalternar entre 'oculto' e 'mostrar'

Estou usando idéias deComo criar um <img> oculto em JavaScript?

Eu tenho dois botões diferentes, tentando um usando html e outro para usar javascript - se eu comentar uma linha, a foto da lâmpada será exibida

 //document.getElementById("light").style.visibility = "hidden";

Essa linha de código está na minhafunção 'init'

Se eu não comentar a linha, a luz permanece 'oculta', não importa em qual botão eu clico

Não vejo nenhum erro no console da Web, logon no Safari

 <!DOCTYPE html>
 <html>
 <body>

 <h1>Switch on the Light</h1>

 <img id="light" src="WebVuCoolOldBulb-2.jpg" style="width:100px" >

 <button type = button

 onclick="document.getElementById('light').src.show ='WebVuCoolOldBulb-2.jpg'"  >Switch On the Light

 </button>
   <input type="button" id="onButton" value="ON" />

 </body>

 <script>

 //document.images['light'].style.visibility = hidden;

  function init() {
     //document.getElementById("light").style.visibility = "hidden";
     var onButton = document.getElementById("onButton");
     onButton.onclick = function() {
        demoVisibility() ;

     }
   }

 function demoVisibility() {
     document.getElementById("light").style.visibility = "show";

 }
  document.addEventListener('readystatechange', function() {
   // Seems like a GOOD PRACTICE - keeps me from getting type error I was getting

     // https://stackoverflow.com/questions/14207922/javascript-error-null-is-not-an-object

     if (document.readyState === "complete") {
       init();
     }
   });



 </script>
 </html>

questionAnswers(1)

yourAnswerToTheQuestion