• 회원가입
  • 로그인
  • 구글아이디로 로그인

[DOM_Element] JS - clientWidth 속성 ★ - 요소너비 (= 요소가시너비 = clientWidth속성 = 클라이언트위드스속성) ※ 문서의 현재 보이는 영역 너비

목차

  1. clientWidth 예제 - 요소 가시 너비
  2. clientWidth 정의
  3. clientWidth 구문
  4. clientWidth 예제 - offsetWidth와의 차이점
  5. clientWidth 예제 - 스크롤바 생긴 경우

 

clientWidth 예제 - 요소 가시 너비

 

<style>

#hz {

  height: 250px;

  width: 400px;

  padding: 10px;

  margin: 15px;

  border: 5px solid blue;

  background-color: yellow;

}

</style>


<button onclick="homzzang()">클릭</button>


<div id="hz">

  <b>div 정보</b><br>

  Height: 250px<br>

  Width: 400px<br>

  padding: 10px<br>

  margin: 15px<br>

  border: 5px<br>

  <p id="demo"></p>

</div>


<script>

function homzzang() {

  var box = document.getElementById("hz");

  var txt = "padding 포함 높이: " + box.clientHeight + "px<br>";

  txt += "padding 포함 너비: " + box.clientWidth + "px";

  document.getElementById("demo").innerHTML = txt;

}

</script>


결과보기

 

clientWidth 정의

 

padding 포함한 px단위의 요소 가시너비 반환.

(※ border, scrollbar, margin 제외)

 


 

1.

  • 가시(可視) 표현 사용 이유 (= 보이는 부분 표현 사용 이유) : 요소 내용물이 요소보다 큰 경우, 보이는 너비만 반환하기 때문. (아래 예제2) 즉, 스크롤바 생긴 경우 스크롤바 두께만큼 제외.
  • 이 개념 이해하려면, CSS BOX모델 선행학습 필요.
  • clientHeight 속성과 종종 함께 쓰임.


2. cf.

scrollWidth 속성 - 문서의 전체너비 (= 총 콘텐츠너비)

3. 

padding, border, scrollbar 포함한 가시너비는 아래 속성 이용

 

4.

요소에 스크롤바 추가하려면, CSS overflow 속성 이용.

 

5. 

모든 브라우저  지원.

 

6. MDN clientWidth 예제보기

https://developer.mozilla.org/en-US/docs/Web/API/Element/clientWidth

 

 

clientWidth 구문

 

element.clientWidth

 

 

clientWidth 예제 - offsetWidth와의 차이점

 

<style>

#hz {

  height: 250px;

  width: 400px;

  padding: 10px;

  margin: 15px;

  border: 5px solid blue;

  background-color: yellow;

}

</style>


<button onclick="homzzang()">클릭</button>


<div id="hz">

  <b>div 정보</b><br>

  Height: 250px<br>

  Width: 400px<br>

  padding: 10px<br>

  margin: 15px<br>

  border: 5px<br>

  <p id="demo"></p>

</div>


<script>

function homzzang() {

  var box = document.getElementById("hz");

  var txt = "";

  txt += "padding 포함 높이: " + box.clientHeight + "px<br>";

  txt += "padding, border 포함 높이: " + box.offsetHeight + "px<br>";

  txt += "padding 포함 너비: " + box.clientWidth + "px<br>";

  txt += "padding, border 포함 너비: " + box.offsetWidth + "px";

  document.getElementById("demo").innerHTML = txt;

}

</script>


결과보기

 

clientWidth 예제 - 스크롤바 생긴 경우

 

<style>

#hz1 {

  height: 250px;

  width: 400px;

  padding: 10px;

  margin: 15px;

  border: 5px solid red;

  background-color: silver;

  overflow: auto;

}


#hz2 {

  height: 250px;

  width: 400px;

  padding: 10px;

  margin: 15px;

  border: 5px solid red;

  background-color: silver;

}


#content {

  height: 500px;

  width:750px ;

  background-color: yellow;

}

</style>


<button onclick="homzzang()">클릭</button>


<div id="hz1">

  <div id="content"></div>

</div>


<div id="hz2">

  <div id="content2"></div>

</div>


<script>

function homzzang() {

  var box1 = document.getElementById("hz1");

  var txt = "";

  txt += "<b>box1 정보:</b><br>"; // 스크롤바 있는 경우

  txt += "padding 포함 높이: " + box1.clientHeight + "px<br>";

  txt += "padding, border, scrollbar 포함 높이: " + box1.offsetHeight + "px<br>";

  txt += "padding 포함 너비: " + box1.clientWidth + "px<br>";

  txt += "padding, border, scrollbar 포함 너비: " + box1.offsetWidth + "px";

  document.getElementById("content").innerHTML = txt;


  var box2 = document.getElementById("hz2");

  var txt2 = "";

  txt2 += "<b>box2 정보:</b><br>"; // 스크롤바 없는 경우

  txt2 += "padding 포함 높이: " + box2.clientHeight + "px<br>";

  txt2 += "padding, border, scrollbar 포함 높이: " + box2.offsetHeight + "px<br>";

  txt2 += "padding 포함 너비: " + box2.clientWidth + "px<br>";

  txt2 += "padding, border, scrollbar 포함 너비: " + box2.offsetWidth + "px";

  document.getElementById("content2").innerHTML = txt2;

}

</script>

 

결과보기

※ 스크롤바가 생긴 경우 스크롤바 두께만큼 제외.


분류 제목
DOM_Element JS - isDefaultNamespace() 메서드 - 네임스페이스가 기본값인지 체크
DOM_Element JS - isEqualNode() 메서드 - 노드 동일여부 비교 (IE9 이상)
DOM_Element JS - isSameNode() 메서드 - 노드 동일여부 비교 (IE9 이상. cf. Firefox 지원X)
DOM_Element JS - isSupported() 메서드 - 지정기능이 지정노드에 지원되는지 확인 (※ 사용 비권장)
DOM_Element JS - lang 속성 - 요소의 lang 속성값 설정/반환
DOM_Element JS - lastChild 속성 ★ = 마지막자식노드 (= lastChild속성 = 라스트차일드 속성)
DOM_Element JS - lastElementChild 속성 - 마지막 자식요소 (IE9 이상)
DOM_Element JS - namespaceURI 속성 - 네임스페이스URI (IE9 이상)
DOM_Element JS - nextSibling 속성 - 바로다음 형제노드
DOM_Element JS - nextElementSibling 속성 - 바로다음 형제요소 (IE9 이상)
DOM_Element JS - nodeName 속성 - 노드명 (= 노드이름)
DOM_Element JS - nodeType 속성 ★ - 노드타입 반환 (읽기전용) ※ 노드유형 = 노트형식 = 노드종류
DOM_Element JS - nodeValue 속성 - 지정노드의 노드값 설정/반환 (= nodeValue속성 = 노드밸류속성)
DOM_Element JS - normalize() 메서드 - 공백제거 후, 인접텍스트노드 합치기 (Element경우)
DOM_Element JS - offsetHeight 속성 - 가시높이 (= 요소실제높이 = 요소높이 height+ + paddi…
DOM_Element JS - offsetWidth 속성 ★ = 가시너비 (= 요소실제너비 = 요소너비 width + paddin…
DOM_Element JS - offsetLeft 속성 - 가시좌측위치 (= 가시왼쪽위치) (IE8 이상)
DOM_Element JS - offsetParent 속성 - static 이외의 position 갖는 최근접조상요소 (= 가장가…
DOM_Element JS - offsetTop 속성 - 가시 상단 위치 (IE8 이상)
DOM_Element JS - ownerDocument 속성 - 노드의 소유자문서를 HTMLDocument 객체로 반환
29/67
목록
찾아주셔서 감사합니다. Since 2012