반응형
이미지 크로스 브라우저의 원래 크기를 결정 하시겠습니까?
<img src='xyz.jpg'>
클라이언트 측 에서 크기 조정 의 물리적 크기를 결정하는 신뢰할 수있는 프레임 워크 독립적 인 방법이 있습니까?
두 가지 옵션이 있습니다.
옵션 1:
제거 width
및 height
속성을 읽기 offsetWidth
및offsetHeight
옵션 2 :
자바 스크립트 작성 Image
객체의 설정 src
및 읽기 width
와 height
(당신도 이렇게 페이지에 추가 할 필요가 없습니다).
function getImgSize(imgSrc) {
var newImg = new Image();
newImg.onload = function() {
var height = newImg.height;
var width = newImg.width;
alert ('The image size is '+width+'*'+height);
}
newImg.src = imgSrc; // this must be done AFTER setting onload
}
Edit by Pekka : 의견에서 동의 한대로 이미지의 "onload"이벤트에서 실행되도록 기능을 변경했습니다. 그렇지 않으면 큰 이미지가 height
있고 width
이미지가 아직로드되지 않았기 때문에 아무것도 반환하지 않습니다.
이미지 (적어도 Firefox에서는)에 naturalWidth
/ height 속성이 있으므로 img.naturalWidth
원래 너비를 가져 오는 데 사용할 수 있습니다.
var img = document.getElementsByTagName("img")[0];
img.onload=function(){
console.log("Width",img.naturalWidth);
console.log("Height",img.naturalHeight);
}
이미지를 자바 스크립트 이미지 개체에 미리로드 한 다음 해당 개체의 너비 및 높이 속성을 확인할 수 있습니다.
/* Function to return the DOM object's in crossbrowser style */
function widthCrossBrowser(element) {
/* element - DOM element */
/* For FireFox & IE */
if( element.width != undefined && element.width != '' && element.width != 0){
this.width = element.width;
}
/* For FireFox & IE */
else if(element.clientWidth != undefined && element.clientWidth != '' && element.clientWidth != 0){
this.width = element.clientWidth;
}
/* For Chrome * FireFox */
else if(element.naturalWidth != undefined && element.naturalWidth != '' && element.naturalWidth != 0){
this.width = element.naturalWidth;
}
/* For FireFox & IE */
else if(element.offsetWidth != undefined && element.offsetWidth != '' && element.offsetWidth != 0){
this.width = element.offsetWidth;
}
/*
console.info(' widthWidth width:', element.width);
console.info(' clntWidth clientWidth:', element.clientWidth);
console.info(' natWidth naturalWidth:', element.naturalWidth);
console.info(' offstWidth offsetWidth:',element.offsetWidth);
console.info(' parseInt(this.width):',parseInt(this.width));
*/
return parseInt(this.width);
}
var elementWidth = widthCrossBrowser(element);
사용하기 쉽도록 Gabriel의 두 번째 옵션을 약간 변경하십시오.
function getImgSize(imgSrc, callback) {
var newImg = new Image();
newImg.onload = function () {
if (callback != undefined)
callback({width: newImg.width, height: newImg.height})
}
newImg.src = imgSrc;
}
HTML :
<img id="_temp_circlePic" src="http://localhost/myimage.png"
style="width: 100%; height:100%">
샘플 호출 :
getImgSize($("#_temp_circlePic").attr("src"), function (imgSize) {
// do what you want with the image's size.
var ratio = imgSize.height / $("#_temp_circlePic").height();
});
참고 URL : https://stackoverflow.com/questions/1944280/determine-original-size-of-image-cross-browser
반응형
'code' 카테고리의 다른 글
클래스 이름을 지정하는 가장 좋은 방법은 무엇입니까? (0) | 2020.09.12 |
---|---|
디 컴파일을 방지하기 위해 컴파일 된 Java 클래스를 잠그는 방법은 무엇입니까? (0) | 2020.09.12 |
R에서 여러 줄 주석을 가질 수 있습니까? (0) | 2020.09.11 |
텍스트로 링크 선택 (정확히 일치) (0) | 2020.09.11 |
웹 페이지의 "오버 스크롤"방지 (0) | 2020.09.11 |