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

[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 - exitFullscreen() 메서드 - 전체화면모드 닫기 (IE11 이상)
DOM_Element JS - firstChild 속성 ★ - 첫번째 자식노드
DOM_Element JS - firstElementChild 속성 - 첫번째 자식요소 (IE9 이상)
DOM_Element JS - focus() 메서드 ★ - 포커스 주기/설정. (= focus메서드 = 포커스메서드)
DOM_Element JS - getAttribute() 메서드 ★ - 요소의 속성명 (= 속성이름) 얻기
DOM_Element JS - getAttributeNode() 메서드 - 지정한 속성노드를 객체로 얻기
DOM_Element JS - getBoundingClientRect() 메서드 - 뷰포트 기준 요소크기와 요소위치 반환 (= g…
DOM_Element JS - getElementsByClassName() 메서드 - 클래스선택자 (= 클래스명선택자 = 클래스이…
DOM_Element JS - getElementsBy태그Name() 메서드 - 태그선택자 (= 요소선택자 = 태그명선택자 = 태…
DOM_Element JS - hasAttribute() 메서드 - 지정속성소유여부 (IE9 이상)
DOM_Element JS - hasAttributes() 메서드 - 속성소유여부 (IE9 이상)
DOM_Element JS - hasChildNodes() 메서드 - 자식노드유무 체크 (= hasChildNodes메서드 = 해…
DOM_Element JS - id 속성 = 아이디 설정/반환
DOM_Element JS - innerHTML 속성 ★ - 요소내용 설정/반환 (= innerHTML속성 = 이너에이치티엠엘속성…
DOM_Element JS - innerText 속성 ★★ - 요소의 텍스트(문자열) 내용과 모든 하위 항목 설정/반환. (= i…
DOM_Element JS - insertAdjacentElement() 메서드 - 지정요소를 지정위치에 삽입 (IE8 이상)
DOM_Element JS - insertAdjacentHTML() 메서드 ★ - HTML문자열을 지정위치에 삽입 (= inser…
DOM_Element JS - insertAdjacentText() 메서드 - 텍스트문자열을 지정위치에 삽입
DOM_Element JS - insertBefore() 메서드 - 기존자식노드 앞에 새 자식노드 삽입
DOM_Element JS - isContentEditable 속성 - 요소내용 편집가능여부 표시
28/67
목록
찾아주셔서 감사합니다. Since 2012