[jquery] AND 및 OR 연산자를 사용하여 속성별로 jQuery 선택

jQuery에서 AND 및 OR를 사용하여 명명 된 속성으로 요소를 선택할 수 있는지 생각하고 있습니다.

예:

<div myid="1" myc="blue">1</div>
<div myid="2" myc="blue">2</div>
<div myid="3" myc="blue">3</div>
<div myid="4">4</div>

1 또는 3 myc="blue"으로 myid설정된 요소 만있는 모든 요소를 ​​선택하고 싶습니다 .

그래서 나는 시도했다.

a=$('[myc="blue"] [myid="1"]  [myid="3"]');

그러나 작동하지 않습니다.

a=$('[myc="blue"] && [myid="1"] || [myid="3"]');

특별한 필터 기능을 작성하지 않고도 가능합니까?



답변

AND 연산

a=$('[myc="blue"][myid="1"][myid="3"]');

OR 연산, 쉼표 사용

a=$('[myc="blue"],[myid="1"],[myid="3"]');

@Vega가 언급했듯이 :

a=$('[myc="blue"][myid="1"],[myc="blue"][myid="3"]');


답변

다중 선택기 [문서] (OR)를 사용하여 .filter() [문서] (AND)를 간단하게 사용 :

$('[myc="blue"]').filter('[myid="1"],[myid="2"]');

일반적으로 연결 선택자는 a.foo.bar[attr=value]일종의 AND 선택기와 같습니다.

jQuery에는 지원되는 선택기에 대한 광범위한 문서 가 있으므로 읽어 볼 가치가 있습니다.


답변

아래와 같이 필터를 작성하는 것은 어떻습니까?

$('[myc="blue"]').filter(function () {
   return (this.id == '1' || this.id == '3');
});

편집 : @ 잭 감사합니다 .. 완전히 놓쳤습니다 ..

$('[myc="blue"]').filter(function() {
   var myId = $(this).attr('myid');
   return (myId == '1' || myId == '3');
});

데모


답변

선택기의 and 연산자는 빈 문자열이고 or 연산자는 쉼표입니다.

그러나 그룹화 또는 우선 순위가 없으므로 다음 조건 중 하나를 반복해야합니다.

a=$('[myc=blue][myid="1"],[myc=blue][myid="3"]');


답변

먼저 모든 상황에서 발생하는 조건을 찾은 다음 특수 조건을 필터링합니다.

$('[myc="blue"]')
    .filter('[myid="1"],[myid="3"]');


답변

당신의 특별한 경우에는

a=$('[myc="blue"][myid="1"],[myc="blue"][myid="3"]');


답변

JQuery는 CSS 선택기를 사용하여 요소를 선택하므로 다음과 같이 쉼표로 구분하여 둘 이상의 규칙을 사용해야합니다.

a=$('[myc="blue"], [myid="1"], [myid="3"]');

편집하다:

죄송합니다. 파란색과 1 또는 3을 원하셨습니다. 어떻습니까?

a=$('[myc="blue"][myid="1"],  [myid="3"]');

두 속성 선택기를 함께 사용하면 AND가 제공되고 쉼표를 사용하면 OR이 제공됩니다.