Javascript Image onLoad

后端 未结 3 1264
佛祖请我去吃肉
佛祖请我去吃肉 2020-12-01 14:36

Why does the onLoad not get triggered?

      function FULL_IMAGE(fimage){
        document.getElementById(\"FULL_SRC\").onLoad = function(){
          offset         


        
3条回答
  •  一向
    一向 (楼主)
    2020-12-01 15:23

    The definition of the event is found inside of a function block. While I have not referenced the ECMAScript specification, I can only guess that the function keyword associates the function body code with the FULL_IMAGE symbol and does not actually enter/execute the code. Therefore, it becomes necessary for the function FULL_IMAGE to be called from the global block in order to register the event. Alternatively, the event registration code can be placed in the global block. This is all of course assuming that a FULL_SRC id has been given to an element on the given HTML document.

    Given the comment, the following has been posted:

    (Option 1)

      document.getElementById("FULL_SRC").onLoad = function(){
        offsetTop = document.getElementById("FULL_SRC").height / 2;
        offsetLeft = document.getElementById("FULL_SRC").width / 2;
        document.getElementById("FULL_SRC").style.marginTop="-"+offsetTop+"px";
        document.getElementById("FULL_SRC").style.marginLeft="-"+offsetLeft+"px";
      }
    
      function FULL_IMAGE(fimage){
        document.getElementById("FULL_SRC").src=fimage;
        document.getElementById("FULL_VIEW").style.display="block";
      }
    

    (Option 2)

      function FULL_IMAGE(fimage){
        document.getElementById("FULL_SRC").onLoad = function(){
          offsetTop = document.getElementById("FULL_SRC").height / 2;
          offsetLeft = document.getElementById("FULL_SRC").width / 2;
          document.getElementById("FULL_SRC").style.marginTop="-"+offsetTop+"px";
          document.getElementById("FULL_SRC").style.marginLeft="-"+offsetLeft+"px";
        }
        document.getElementById("FULL_SRC").src=fimage;
        document.getElementById("FULL_VIEW").style.display="block";
      }
    
      FULL_IMAGE (myParameter);
    

提交回复
热议问题