2017-09-28 5 views
1

질문이 있습니다. 아래 코드에서 base64를 src로 설정하면 img.onload가 실행되지 않습니다. 그러나 src에 직접 이미지를 설정하면 img.onload가 실행되고 console.log는 "image is loaded"를 반환합니다. img.onload가 base64 문자열이 아닌 이미지 일 때만 해고 당할 이유를 설명해 주시겠습니까? 또한 base64 문자열을 만드는 방법 img.onload.base64 svg 문자열을 이미지 태그 src로 설정하는 방법은 무엇입니까?

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 
<html> 

<head> 

</head> 

<body style="background-color:#F5F5F6;"> 
</body> 
<script> 
    (function() { 
     var b64 = 
      ""; 

     function Jeff() { 
      var img = new Image(); 
      document.body.appendChild(img); 
      img.setAttribute("src",b64); 
      img.onload = function() { 
       // document.getElementsByTagName("body")[0].appendChild(this); 
       console.log("image is loaded"); 
      }; 
      img.src = b64; 
      // img.src = "http://pierre.chachatelier.fr/programmation/images/mozodojo-original-image.jpg"; 
     } 
     Jeff(); 
    })(); 
</script> 

</html> 

감사합니다. 제프린.

+1

질문에 답변이 있으면 실제로 답변을 변경할 수 없으므로 답변에서 더 이상 문제가 해결되지 않습니다. 더 많은 질문이 있으시면 별도로 질문하십시오. 문맥을 추가 할 것으로 생각되면이 질문에 대한 링크를 항상 새 질문에 포함 할 수 있습니다. –

+0

ok 죄송합니다. @ RobertLongson –

답변

1

srcimg 인 svg의 기본 64 문자열을 설정해야합니다. 예를 들어, 아래 간단한 base64로 SVG 문자열을 시도 : 그것은 문제처럼 보인다



은 SVG가 잘못 형성되어 있다는 점이다. base64에서 디코딩 한 후에는 몇 개의 div로 둘러 쌉니다 (예 : 제목, 범례).

https://jsfiddle.net/b7kru6e0/

을 그리고 당신은/앞에 추가 HTML로 다른 구성 요소를 추가 할 수 있습니다 : 당신은 그냥 차트 SVG 자체를 가지고베이스 64로 인코딩하면 작동합니다.

+0

오 .. 알았어! 빠른 답변을 주셔서 감사합니다. @J S –

+0

안녕하세요, 제발 내 편집 좀 봐주세요. 2 @J S –

관련 문제