jQuery의 세 가지 $() 유형에 대한 자세한 설명 php中世界最好的语言 원래의
2018-04-20 09:08:59 2165검색
이번에는 jQuery의 세 가지 $() 유형 사용에 대해 자세히 설명하겠습니다. jQuery의 $() 세 가지 유형을 사용할 때 주의 사항 은 무엇입니까? 다음은 실제 사례입니다.
$ 기호는 jQuery "클래스"의 별칭이며 $()는 jQuery 개체를 구성합니다. 따라서 "$()"는 jQuery의 constructor 라고 할 수 있습니다(개인적인 의견, 하하!).
1. $()는 $(expression), 즉 css selector , Xpath 또는 html 요소일 수 있습니다. 즉, 대상 요소는 위의 표현식을 통해 일치됩니다. 예를 들어 $("a")로 생성된 객체는 CSS 선택기를 사용하여 jQuery 객체를 생성합니다. 이는 모든 태그를 선택합니다. 예: $("a").click(function(){...}) 은 페이지의 링크를 클릭할 때 트리거 이벤트입니다. 정확하게 말하면 jQuery는 태그를 사용하여 $("a") 객체를 생성하며 click() 함수는 이 jQuery 객체의 (이벤트) 메서드입니다. 예를 들어 다음과 같은 HTML 코드가 있습니다.
<p>one</p>
<p>
<p>two</p>
</p>
<p>three</p>
<a href="#" id="test" onClick="jq()" >jQuery</a>
이 HTML의 작업은 다음 문입니다.
alert($("p>p").html());
$()는 "p>p"와 같은 쿼리 표현식으로 구성된 쿼리 표현식입니다. jQuery 객체를 얻은 다음 "html()"은 위 HTML 코드 조각의 [2]인 html 콘텐츠를 표시한다는 의미입니다. 또 다른 예:
$("<p><p>Hello</p></p>").appendTo("body");
$()에는 문자열이 포함되어 있습니다. 이러한 문자열을 사용하여 jQuery 객체를 구성한 다음 이 문자열을
에 추가하세요.
2. $()는 특정 DOM 요소인 $(element)일 수 있습니다. 예를 들어 일반적으로 사용되는 DOM 개체에는 문서, 위치, 양식 등이 포함됩니다. 예를 들어 다음 코드 줄은 다음과 같습니다.
$(document).find("p>p").html());
$()의 문서는 DOM 요소입니다. 즉, 전체 텍스트에
가 있는
요소를 검색하고 < ;피>. 3. $()는 $(function), 즉 $(document).ready()의 약어일 수 있습니다. 예를 들어 일반적인 형식은 다음과 같습니다:
$(document).ready(function(){
alert("Hello world!");
});
Deformable:
$(function(){
alert("Hello world!");
});
对于选择HTML文档中的elements,jQuery有两种方法: 1)如$("p>ul a"),它的意思是p标签中的ul标签中的a标签 不过,$('p>ul')和$('p ul')是有区别的, $('p>ul')是
的直接后代里找
; 而$('p ul')是在的所有后代里找
。 2)用jQuery对象的几个方法(如方法find()、each()等) $("#orderedlist).find("li") 就像 $("#orderedlist li"). each()一样迭代了所有的li,而表达式中的“#”表示HTML中的ID,如上例中的“#orderedlist”就表示“ID为orderedlist所在的标签”。 **************************************************************** 1、标签选择器 $('p')、类选择器 $('.myClass')、id选择器$('#myId')相对简单,不多说。不过有一点——$('p>ul')和$('p ul')是有区别的, $('p>ul')是的直接后代里找
;而$('p ul')是在的所有后代里找
。 所以,$('#sId>li')所选择的是id为"sId"的所有孩子节点,即使这个 的后代还有 也不是它所找的范围(所找到的DOM对象,只是它本级的DOM对象。)。而$('#sId li:not(.horizontal)'),就是指类名"sId"里面的所有li的子孙中没有horizontal类的所有元素。——这里的not()是一个negation pseudo class. 这里返回的是一个jQurey对象,一个数组对象,这个jQuery对象的长度可用.length()得到。 2、XPath选择器 如:选择所有带有title 属性的链接,我们会这样写:$('a[@title]') []里带@,说明[]里的是元素的属性;是个属性选择器 []里没@,说明[]里的是元素的子孙。 $('ul li')和$('ul[li]')虽然返回的都是一个jQuery数组,但两者的含义正好相反。前者是要找下所有子孙,而后者却是在找所有子孙为 的数组。 在XPath中,要找一个“以...开头”的属性,用^=,如找一个name属性是以mail开头的input元素,就用 $('input[@name^="mail"]') 要找一个“以...结尾”的属性,要用$= 要找一个“不头不尾”的属性,用*= 3、不属于上述的CSS和XPath的选择器,就是自定义的选择器了,用“:”表示,这里要用的就是:first,:last,:parent ,:hidden,:visible,:odd,:even,:not('xxx'), ":eq(0)"(始于0),:nth(n),:gt(0),:lt(0),:contains("xxx") 如:$('tr:not([th]):even')意为元素的子孙中不含的所有子孙的偶数项 4、还有几个,简单不解释了 $('th').parent()—— $('td:contains("Henry")').prev()——内容包含有"Henry"的 的上一个节点 $('td:contains("Henry")').next()——内容包含有"Henry"的 的下一个节点 $('td:contains("Henry")').siblings()——内容包含有"Henry"的 的所有兄弟节点 还有一个,就是end(),这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end()。用过end()方法之后,所返回的是执行动作的那个节点的父节点上。举个例子 $(...).parent().find(...).addClass().end() 这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass()”,之后,用了个end(),这时所返回的东东就是指向了parent()所指向的节点,也就是执行“addClass()”动作的那个数组对象的父节点。 5、要直接访问DOM元素,可用get(0)的方法,如 $('#myelement').get(0),也可缩写成$('#myelement')[0]
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
HTML常用的属性知识点总结
H5设计时的小技巧总结
H5+C3+JS로 바닥 점프 특수 효과 구현
위 내용은 jQuery의 세 가지 $() 유형에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
성명: 본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.