jQuery метод .innerHeight()

jQuery DOM методы

Определение и применение

jQuery метод .innerHeight() получает текущее вычисленное значение внутренней высоты (включая внутренние отступы - padding, но не границы - border) для первого элемента в наборе совпавших элементов, или устанавливает внутреннюю высоту каждого соответствующего элемента.

Наглядное отображение использования jQuery методов .innerHeight() и .innerWidth().

Наглядное отображение использования jQuery методов .innerHeight() и .innerWidth().

Для получения текущего значения вычисленного значения внутренней ширины элемента (включая внутренние отступы, границы и при необходимости внешние отступы) для первого элемента в наборе совпавших элементов, или установить внутреннюю ширину каждого соответствующего элемента вы можете воспользоваться методом .innerWidth().

Метод .innerHeight() возвращает значение высоты элемента, включая нижние и верхние внутренние отступы в пикселях. Если метод вызывается на отсутствующем элементе, то возвращаемое значение будет undefined (до версии jQuery 3.0 значение null).


Этот метод не применяется к таким объектам как window, или document. Для этих целей используйте метод .height().


jQuery метод .innerHeight() не гарантирует точность в том случае, когда элемент, или его родитель скрыт. Чтобы получить точное значение, убедитесь, что элемент является видимым перед использованием метода. jQuery будет пытаться временно показать, а затем снова скрыть элемент для того, чтобы измерить его размеры, но в этом случае метод не является надежным, это может влиять на производительность страницы. Подобная функция измерения может быть удалена в следующей версии библиотеки jQuery.

jQuery синтаксис:

Получение значения:
Синтаксис 1.0:
$( selector ).innerHeight() // метод используется без параметров

Установка значений:
Синтаксис 1.0:
$( selector ).innerHeight( value ) 

value - String (значение в произвольных единицах измерения), или Integer (значение в пикселях)

Синтаксис 1.8.0:
$( selector ).innerHeight(function( index, currentValue )) 

index - Integer
currentValue - Number.

Добавлен в версии jQuery

1.0 (синтаксис обновлен в 1.8.0)

Значения параметров

ПараметрОписание
valueПараметр определяет значение внутренней высоты, которое будет установлено. Допускается указывать любые единицы измерения CSS, либо указывать только числовое значение без единиц измерения, в этом случае значение будет установлено в пикселях.
Обратите внимание, что свойство height не включает в себя внутренние отступы, границу, или внешние отступы, если используется CSS свойство box-sizingcss3 со значением content-box (значение по умолчанию).
function(index, currentValue)Определяет функцию, которая возвращает новое значение внутренней высоты, которое будет установлено выбранным элементам. Внутри функции this ссылается на текущий элемент в наборе.
index - возвращает индекс элемента в наборе.
currentValue - текущее значение внутренней высоты элемента.

Пример использования

<!DOCTYPE html>
<html>
	<head>
		<title>Использование jQuery метода .innerHeight() (возвращение значения)</title>
		<style></style>
		<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
		<script>
	$( document ).ready(function(){
	  var innerHeightFirst = $( ".first" ).innerHeight(); // инициализируем переменную со значением внутренней высоты элемента с классом first
	  var innerHeightSecond = $( ".second" ).innerHeight(); // инициализируем переменную со значением внутренней высоты элемента с классом second
	  $( ".first" ).text( "content-box" + innerHeightFirst ); // добавляем текстовое содержимое элементу с классом first
	  $( ".second" ).text( "border-box" + innerHeightSecond ); // добавляем текстовое содержимое элементу с классом second
	});
		</script>
	</head>
	<body>
		<div class = "first"></div>
		<div class = "second"></div>
	</body>
</html>

В этом примере мы при загрузке документа с использованием jQuery метода .innerHeight() инициализируем переменные, которые содержат значением внутренней высоты элемента с классом first и с классом second. После этого с использованием метода .text() добавляем эти значения внутри элементов с классом first и с классом second.

Обратите внимание, что свойство height не включает в себя внутренние отступы, границу, или внешние отступы, если используется CSS свойство box-sizingcss3 со значением content-box (значение по умолчанию).

Результат нашего примера:

Пример использования jQuery метода .innerHeight() (возвращение значения)
Пример использования jQuery метода .innerHeight() (возвращение значения)

Рассмотрим следующий пример в котором мы как получитм, так и установим значение внутренней высоты:

<!DOCTYPE html>
<html>
	<head>
		<title>Использование jQuery метода .innerHeight() (установка значения)</title>
		<style></style>
		<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
		<script>
	$( document ).ready(function(){
	  var innerHeightFirst = $( ".first" ).innerHeight(); // инициализируем переменную со значением внутренней высоты элемента с классом first
	  var innerHeightSecond = $( ".second" ).innerHeight(); // инициализируем переменную со значением внутренней высоты элемента с классом second
	  $( ".first" ).text( "content-box " + innerHeightFirst); // добавляем текстовое содержимое элементу с классом first
	  $( ".second" ).text( "border-box " + innerHeightSecond); // добавляем текстовое содержимое элементу с классом second
	  
	  $( "button" ).click(function(){
	    $( ".first" ).innerHeight(50); // устанавливаем новое значение внутренней высоты элемента с классом first
	    $( ".second" ).innerHeight(50); // устанавливаем новое значение внутренней высоты элемента с классом second
	    innerHeightFirst = $( ".first" ).innerHeight(); // присваиваем переменной текущее значение внутренней высоты элементы с классом first
	    innerHeightSecond = $( ".second" ).innerHeight(); // присваиваем переменной текущее значение внутренней высоты элементы с классом second
	    $(".first").text( "content-box " + innerHeightFirst); // добавляем новое текстовое содержимое элементу с классом first
	    $(".second").text( "border-box " + innerHeightSecond); // добавляем новое текстовое содержимое элементу с классом second
	  });
	});
		</script>
	</head>
	<body>
		<div class = "first"></div>
		<div class = "second"></div>
	</body>
</html>

В этом примере по аналогии с предыдущим примером мы при загрузке документа с использованием jQuery метода .innerHeight() инициализируем переменные, которые содержат значением внутренней высоты элемента с классом first и с классом second. После этого с использованием метода .text() добавляем эти значения внутри элементов с классом first и с классом second.

Кроме того, мы разместили кнопку, при нажатии на которую, мы устанавливаем внутреннюю высоту равную 50 пикселям каждому элементу. При этом зрительно мы получим один и тот же результат независимо от значения свойства box-sizingcss3, но при этом учитывайте, что значение высоты (height) у элементов будет разным.

Результат нашего примера:

Пример использования jQuery метода .innerHeight() (установка значения)
Пример использования jQuery метода .innerHeight() (установка значения)

Рассмотрим следующий пример в котором мы передадим в качестве параметра метода .innerHeight() функцию:

<!DOCTYPE html>
<html>
	<head>
		<title>Использование jQuery метода .innerHeight() (функция в качестве параметра)</title>
		<style></style>
		<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
		<script>
	$( document ).ready(function(){
	  $( "button" ).click(function(){
	    var x = $( "div" ).innerHeight(); // инициализируем переменную, содержащую внутреннюю высоту первого элемента <div>
	    $( "div" ).innerHeight(function(index, currentInnerHeight){
	      x += 30; // увеличиваем значение переменной x
	      return currentInnerHeight+=x;  // возвращаем новое значение внутренней высоты элемента с текущим индексом
	    });
	  });
	});
		</script>
	</head>
	<body>
		<div></div>
		<div></div>
		<div></div>
	</body>
</html>

В этом примере мы при нажатии на кнопку передаем методу .innerHeight() функцию, которая возвращает новое значение внутренней высоты и устанавливает её выбранным элементам в зависимости от их индекса. Перед каждой установкой значения, мы увеличиваем значение переменной на 30 и прибавляем его к значению внутренней высоты элемента.

Результат нашего примера:

Пример использования jQuery метода .innerHeight() (функция в качестве параметра)
Пример использования jQuery метода .innerHeight() (функция в качестве параметра)
jQuery DOM методы
×

Кажется, вы используете блокировщик рекламы :(

Этот ресурс не является коммерческим проектом и развивается на энтузиазме автора сайта, который посвящает все свое свободное время этому проекту.

Добавьте, пожалуйста, basicweb.ru в исключения блокировщика рекламы, этим вы поможете развитию проекта.