javascript добавить - Проверьте, существует ли div с определенным именем класса




проверить существование (13)

Используя jQuery, я программно генерирую кучу div 's следующим образом:

<div class="mydivclass" id="myid1">Some Text1</div>
<div class="mydivclass" id="myid2">Some Text2</div>

Где-то в моем коде мне нужно определить, существуют ли эти DIV. Имя класса для divs совпадает с идентификатором для каждого div. Любая идея, как их обнаружить с помощью jQuery?


Answers

Это довольно просто ...

if ($('.mydivclass').length > 0) {
  //do something
}

Вы можете использовать size() , но jQuery рекомендует использовать длину, чтобы избежать накладных расходов на другой вызов функции:

$('div.mydivclass').length

Так:

// since length is zero, it evaluates to false
if ($('div.mydivclass').length) {

http://api.jquery.com/size/

http://api.jquery.com/length/

ОБНОВИТЬ

Выбранный ответ использует перфекционный тест, но он немного ошибочен, так как он также включает в себя выбор элементов в составе перфоратора, который не является тем, что тестируется здесь. Вот обновленный перфекционный тест:

http://jsperf.com/check-if-div-exists/3

Мой первый запуск теста показывает, что поиск свойств быстрее, чем поиск индекса, хотя ИМО это довольно незначительно. Я по-прежнему предпочитаю использовать длину, так как для меня более разумно понимать намерение кода вместо более сложного условия.


Существует много способов проверить существование div с определенным именем класса. Ниже приведены некоторые полезные способы:

1.  if($("div").hasClass("mydivclass")){//Do any thing}

   // It returns true if any div has 'mydivclass' name. It is a based on the class name

2. if($("#myid1").hasClass("mydivclass")){//Do any thing}

   //  It returns true if specific div(myid1) has this class "mydivclass" name. 
   //  It is a  based on the specific div id's.

3. if($("div[class='mydivclass']").length > 0){//Do any thing}

   // It returns all the divs whose class name is "mydivclass"
  //  and it's length would be greater than one.

Мы можем использовать любой из определенных способов, основанных на требовании.


if ($(".mydivclass").size()){
   // code here
}

Метод size() просто возвращает количество элементов, которые выбирает селектор jQuery - в этом случае количество элементов с классом mydivclass . Если он возвращает 0, выражение является ложным, и поэтому его нет, и если он возвращает любое другое число, div должны существовать.


Без jQuery:

Собственный JavaScript всегда будет быстрее. В этом случае: (example)

if (document.querySelector('.mydivclass') !== null) {
    // .. it exists
}

Если вы хотите проверить, содержит ли родительский элемент другой элемент с определенным классом, вы можете использовать одно из следующих. (example)

var parent = document.querySelector('.parent');

if (parent.querySelector('.child') !== null) {
    // .. it exists as a child
}

В качестве альтернативы вы можете использовать метод .contains() для родительского элемента. (example)

var parent = document.querySelector('.parent'),
    child = document.querySelector('.child');

if (parent.contains(child)) {
    // .. it exists as a child
}

.. и, наконец, если вы хотите проверить, содержит ли данный элемент только определенный класс, используйте:

if (el.classList.contains(className)) {
    // .. el contains the class
}

var x = document.getElementsByClassName("class name");
if (x[0]) {
alert('has');
} else {
alert('no has');
}

Для проверки элементов div явно:

if( $('div.mydivclass').length ){...}


Вы можете упростить это, проверив первый объект, который возвращается из JQuery следующим образом:

if ($(".mydivclass")[0]){
    // Do something if class exists
} else {
    // Do something if class does not exist
}

В этом случае, если в первом ( [0] ) индексе есть истинное значение, то предположим, что класс существует.

Редактировать 04/10/2013: Я создал тестовый пример jsperf.


Лучший способ в Javascript:

if (document.getElementsByClassName("search-box").length > 0) {
// do something
}

$('div').hasClass('mydivclass')// Returns true if the class exist.

проверьте, существует ли div с определенным классом

if ($(".mydivclass").length > 0) //it exists 
{

}

Простой код приведен ниже:

if ($('.mydivclass').length > 0) {
   //Things to do if class exist
}

Чтобы скрыть div с идентификатором участника:

if ($('#'+given_id+'.mydivclass').length > 0) {
   //Things to do if class exist
}

Существует string.includes в ES6 :

"potato".includes("to");
> true

Обратите внимание, что вам может потребоваться загрузить es6-shim или аналогичный, чтобы это работало в старых браузерах.

require('es6-shim')




javascript jquery jquery-selectors javascript-framework