Rumah >hujung hadapan web >tutorial js >Ringkasan fungsi JQuery dan functions_jquery yang biasa digunakan
1. 문서 로딩 완료 실행 기능
$(document).ready(function(){ alert("开始了"); });
2. CSS 클래스 추가/제거
$("#some-id").addClass("NewClassName"); $("#some-id").removeClass("ClassNameToBeRemoved");
3. 선택기는 CSS 및 Xpath(XML 경로 언어) 선택기와 jQuery의 고유 선택기 기능을 활용합니다.
3.1 자주 사용되는 단어:
1. 태그 이름에 따라 문서의 모든 단락을 선택합니다: $('p')
2. ID에 따라: $("#some-id")
3. 클래스: $('.some-class')
3.2 CSS 선택기 사용:
$("#some-id > li") 选择特定id下的所有子li元素 $("#some-id li:not(.horizontal)") 伪类选择,特定id下所有没有.horizontal 类的li元素
3.3 XPath 선택기 사용:
속성 선택: $("a[@title]")는 제목 속성이 있는 모든 링크를 선택합니다
$("div[ol]")은 ol 요소가 포함된 모든 div 요소를 선택합니다
$('a[@href^="mailto:%22]')는 모든 href 속성[@href]을 선택하고 속성 값은 mailto^="mailto"로 시작합니다(^는 $ 문자열 매듭으로 시작하는 문자열을 식별합니다).
꼬리, *는 문자열의 임의 위치를 나타냄)
$('a[@href$=".pdf"]')는 href 속성이 있는 모든 링크를 선택하고 속성 값은 .pdf로 끝납니다.
$('a[@href*="mysite.com"]')은 mysite.com이 href(mysite.com 포함) 어디에나 나타나는 모든 링크를 선택합니다.
3.4JQuery 사용자 정의 선택기(필터링, 선택한 결과 집합에서 특정 조건을 충족하는 모든 요소 필터링), ":"으로 시작하는 CSS 의사 클래스 선택기와 유사
1.$('div.horizontal:eq(1)')은 수평 클래스를 사용하여 div 컬렉션에서 두 번째 항목을 선택합니다
$('div:nth-child(1)')는 상위 요소의 첫 번째 하위 요소인 모든 div를 선택합니다
2. 맞춤 선택기: 홀수 및 짝수 행 선택
$('tr:odd').addClass('odd'); //결과 집합에서 홀수 요소를 필터링하고 선택합니다
$('tr:even').addClass('even'); //결과 세트에서 짝수 요소를 필터링하고 선택합니다
3. 맞춤 선택기: 포함()
$('td:contains("Henry")')는 Henry 문자열이 포함된 모든 테이블을 선택합니다
3.5JQuery 선택 기능
1.$('#some-id').parent()는 특정 요소의 상위 요소를 선택합니다
2.$('#some-id').next()는 특정 요소의 다음으로 가장 가까운 형제 요소를 선택합니다
3.$('#some-id').siblings()는 특정 요소의 모든 형제 요소를 선택합니다
4.$('#some-id').find('.some-class')는 특정 요소 아래에서 특정 클래스를 포함하는 모든 요소를 선택합니다
5.$('#some-id').find('td').not(':contains("Henry")') 특정 요소 아래의 테이블 콘텐츠에 Henry가 포함되지 않은 모든 요소를 선택하세요
5.$('#some-id').find('td').not(':contains("Henry")').end() .end()는 마지막 .find로 돌아가는 것을 의미합니다.
의 ( ) 요소
3.6 DOM 요소에 액세스하고, get() 메서드를 사용하여 선택한 JQuery 객체에서 가져오고, JQuery 패키징을 제거합니다.
var myTag = $('#some-id').get(0).tagName; var myTag = $('#some-id')[0].tagName; //与上面的等效
4. 이벤트(모든 이벤트는 특정 요소에 바인딩됨)
4.1 바인딩 이벤트
$("#some-id").bind("click", function(){ }) $("#some-id").unbind("click", bindedFunctionName); //移除已绑定的事件,前提是绑定的函数有名称(不是匿名函数) $("#some-id").click(function(){ })
4.2 복합함수 바인딩 이벤트
$("#some-id").toggle(function(){ } ,function(){ }); //交替执行 $(“#some-id”).toggleClass("hidden"); // 添加/删除类交替进行 $("#some-id").hover(function(){ }, function(){ }); //鼠标进入元素时执行第一个函数,离开元素时执行第二个函数 $("#some-id").one("click", functionName); //只需触发一次,随后便立即解除绑定
4.3 사용자를 모방하여 이벤트 발생
$("#some-id").trigger("click"); //특정 요소의 클릭 이벤트 트리거
5. 요소에 효과 추가
5.1 CSS 스타일 속성 읽기 또는 설정
$("#some-id").css("property") //스타일 값 읽기
$('#some-id').css('property', 'value') //스타일 값 설정
$('#some-id').css({property1: 'value1', property2: 'value2'}) //여러 스타일 속성 설정
5.2 글꼴 크기 변경
$(document).ready({ $('#button-id').click(function(){ var currentSize = $('#text-id').css('fontSize'); //获取字体大小,如30px var num = parseFloat(currentSize, 10); //将值转为浮点数,.parseFloat( , )为javascript内置函数,这里是转为10进制的浮点数 var unit = currentSize.slice(-2); //获取单位名称,如px,.slice()是javascript内置函数,获取字符串指从定位置开始的子字符串,-2表示倒数两个字符 num *= 1.5; $('text-id').css('fontSize', num + unit); //设置字体大小样式 }); });
5.3隐藏和显示
$('#some-id').show(); //无效果,会自动记录原来的display属性值(如:block, inline),再回复display值
$('#some-id').hide(); //无效果,等效于:$('#some-id').css('display', 'none'); 隐藏元素,不保留物理位置
大小、透明度逐渐变化的显示或隐藏
$('#some-id').show('slow'); //指定显示速度,在指定时间内元素的高、宽、不透明度逐渐增加到属性值,有:slow是0.6秒,normal是0.4秒,fast是0.2秒,或者直接填入毫秒数
$('#some-id').hide(800); //与.show()指定速度显示一样,指定时间内高、宽、不透明度逐渐减小到0
淡入淡出
$('some-id').fadeIn('slow'); //指定时间内不透明度属性值由0增加到1
$('some-id').fadeOut('slow'); //指定时间内不透明度值由1减小到0
5.4构建具有动画效果的show
主要调用.animate()方法,其有4个参数:包含样式属性及值的映射;可选的速度参数;可选的缓动类型;可选的回调函数;
1.并发显示多个效果
$('#some-id').animate({height: 'show', width: 'show', opacity: 'show'}, 'slow', function(){ alert('动画显示元素');});
$('div .button').animate({left:600, height:44}, 'slow'); //水平位置从0移动到600,高度由0增加到44
2.排队显示多个效果,级联多个.animate(),一个效果显示完了再显示下一个效果
$('#some-id').animate({left:600}, 'slow').animate({height: 44}, 'slow');
6DOM操作
6.1属性操作
$('#some-id').attr('property'); //获取属性 $('#some-id').attr('property','value'); //设置属性 $('#some-id').attr({'property1': 'value1', 'property2': 'value2'}); //设置多个属性 修改一个段落中所有链接,并给每个链接附上新的id号 $('div p .content a').each(function(index){ $(this).attr({ 'rel': 'external', 'id': 'link_' + index }); }); // ********* JQuery的.each()类似一个迭代器,给其传递的参数index类似一个计数器 *********
6.2插入新元素
1.将元素插入到其他元素前面:.insertBefore()和.before()
2.将元素插入到其他元素后面:.insertAfter()和after()
3.将元素插入到其他元素内部或后面(相当于追加一个元素):appendTo()和append()
4.将元素插入到其他元素内部或前面(相当于追加一个元素):prependTo()和prepend()
6.3包装元素,将元素包装到其他元素中 .wrap();
$('#some-id').wrap('25edfb22a4f469ecb59f1190150159c6bed06894275b65c1ab86501b08a632eb'); // 将某一特定元素包装到li中,即在特定元素外围添加一个包围元素
6.4复制元素 .clone()
1.$('#some-id').clone().appendTo($('body'));
2.复制深度,当传入false参数时,只复制匹配上的元素,其内部的其他元素不复制
$('#some-id').clone(false)
注意:.clone()方法不会复制元素中的事件
6.5移除匹配元素中的元素,类似清空元素
$('#some-id').empty();
6.6从DOM中移除匹配的元素及其后代元素
$('#some-id').remove();
有关常用的JQuery函数及功能小结 小编就给大家介绍到这里,希望对大家有所帮助!