国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

前端程序員應(yīng)該知道的 15 個(gè) jQuery 小技巧

開發(fā) 前端
改變scrollTop 的值可以更改你想要放置滾動(dòng)條的位置。所有你真正需要做的是在800毫秒的時(shí)間內(nèi)設(shè)置文檔主體的動(dòng)畫,直到它滾動(dòng)到文檔的頂部。

下面這些簡(jiǎn)單的小技巧能夠幫助你玩轉(zhuǎn)jQuery。

  • 返回頂部按鈕

  • 預(yù)加載圖像

  • 檢查圖像是否加載

  • 自動(dòng)修復(fù)破壞的圖像

  • 懸停切換類

  • 禁用輸入字段

  • 停止加載鏈接

  • 切換淡入/幻燈片

  • 簡(jiǎn)單的手風(fēng)琴

  • 讓兩個(gè)div高度相同

  • 在新標(biāo)簽頁(yè)/窗口打開外部鏈接

  • 通過(guò)文本查找元素

  • 在改變visibility時(shí)觸發(fā)

  • AJAX調(diào)用錯(cuò)誤處理

  • 鏈?zhǔn)讲寮{(diào)用

通過(guò)使用jQuery中的animate 和scrollTop 方法,不用插件就可以創(chuàng)建一個(gè)滾動(dòng)到頂部的簡(jiǎn)單動(dòng)畫:

  1. // Back to top 
  2. $('.top').click(function (e) { 
  3.   e.preventDefault(); 
  4.   $('html, body').animate({scrollTop: 0}, 800); 
  5. }); 
  6.  
  7. <!-- Create an anchor tag --> 
  8. <a class="top" href="#">Back to top</a> 

改變scrollTop 的值可以更改你想要放置滾動(dòng)條的位置。所有你真正需要做的是在800毫秒的時(shí)間內(nèi)設(shè)置文檔主體的動(dòng)畫,直到它滾動(dòng)到文檔的頂部。

注:小心scrollTop的一些錯(cuò)誤行為。

預(yù)加載圖像

如果你的網(wǎng)頁(yè)要使用大量開始不可見(jiàn)的(例如,懸停的)圖像,那么可以預(yù)加載這些圖像:

 

  1. $.preloadImages = function () { 
  2.   for (var i = 0; i < arguments.length; i++) { 
  3.     $('<img>').attr('src', arguments[i]); 
  4.   } 
  5. }; 
  6.  
  7. $.preloadImages('img/hover-on.png''img/hover-off.png'); 

檢查圖像是否加載

有時(shí)為了繼續(xù)腳本,你可能需要檢查圖像是否全部加載完畢:

  1. $('img').load(function () { 
  2.   console.log('image load successful'); 
  3. }); 

你也可以用ID或類替換<img>標(biāo)簽來(lái)檢查某個(gè)特定的圖像是否被加載。

自動(dòng)修復(fù)破壞的圖像

逐個(gè)替換已經(jīng)破壞的圖像鏈接是非常痛苦的。不過(guò),下面這段簡(jiǎn)單的代碼可以幫助你:

  1. $('img').on('error', function () { 
  2.   if(!$(this).hasClass('broken-image')) { 
  3.     $(this).prop('src''img/broken.png').addClass('broken-image'); 
  4.   } 
  5. }); 

即使沒(méi)有任何斷掉的鏈接,加上這一段代碼也不會(huì)讓你有任何損失。

懸停切換類

假設(shè)你希望當(dāng)用戶將鼠標(biāo)懸停在可點(diǎn)擊的元素上時(shí),它會(huì)改變顏色。那么你可以在用戶懸停的時(shí)候添加類到元素中,反之則刪除類:

  1. $('.btn').hover(function () { 
  2.   $(this).addClass('hover'); 
  3. }, function () { 
  4.   $(this).removeClass('hover'); 
  5. }); 

你只需要添加必要的CSS即可。更簡(jiǎn)單的方法是使用toggleClass 方法:

  1. $('.btn').hover(function () { 
  2.   $(this).toggleClass('hover'); 
  3. }); 

注:可能在這種情況下,CSS這種解決方案更快,不過(guò)了解這個(gè)方法很有必要。

禁用輸入字段

有時(shí)候,你可能想要禁用表格的提交按鈕或它的某一項(xiàng)文字輸入直到用戶執(zhí)行了特定操作(例如,勾選“我已閱讀相關(guān)條款”復(fù)選框)。添加 disabled屬性到你的輸入就可以在你想要的時(shí)候才啟用它:

  1. $('input[type="submit"]').prop('disabled'true); 

然后你只需要運(yùn)行輸入的prop 方法就可以了,不過(guò)disabled 的值要設(shè)置為false:

  1. $('input[type="submit"]').prop('disabled'false); 

停止加載鏈接

有時(shí)候,你既不需要鏈接到某個(gè)特定的網(wǎng)頁(yè),也不想要重新加載頁(yè)面——你可能希望鏈接做點(diǎn)別的事情,例如說(shuō)觸發(fā)一些其他腳本。這就要在阻止默認(rèn)動(dòng)作上做文章了:

  1. $('a.no-link').click(function (e) { 
  2.   e.preventDefault(); 
  3. }); 

淡入/滑動(dòng)切換

滑動(dòng)和淡入都是我們用jQuery做動(dòng)畫的時(shí)候大量運(yùn)用的東西。如果你只是想在用戶點(diǎn)擊之后展示一個(gè)元素的話,那么用fadeIn 和slideDown 方法就很***。但是,如果你想要元素在***次點(diǎn)擊的時(shí)候出現(xiàn),然后在第二次點(diǎn)擊的時(shí)候消失的話,那么可以試試下面的代碼:

 

  1. // Fade 
  2. $('.btn').click(function () { 
  3.   $('.element').fadeToggle('slow'); 
  4. }); 
  5.  
  6. // Toggle 
  7. $('.btn').click(function () { 
  8.   $('.element').slideToggle('slow'); 
  9. }); 

簡(jiǎn)單的手風(fēng)琴

這是一個(gè)可快速生成手風(fēng)琴的簡(jiǎn)單方法:

 

  1. // Close all panels 
  2. $('#accordion').find('.content').hide(); 
  3.  
  4. // Accordion 
  5. $('#accordion').find('.accordion-header').click(function () { 
  6.   var next = $(this).next(); 
  7.   next.slideToggle('fast'); 
  8.   $('.content').not(next).slideUp('fast'); 
  9.   return false
  10. }); 

通過(guò)添加這個(gè)腳本,你真正需要做的僅僅是在頁(yè)面上添加必要的HTML元素,這樣它就可以運(yùn)行工作了。

讓兩個(gè)div高度相同

有時(shí)候,你需要讓兩個(gè)div無(wú)論包含什么內(nèi)容都擁有相同的高度:

  1. $('.div').css('min-height', $('.main-div').height()); 

設(shè)置 min-height,這意味著它可以比主div大但絕對(duì)不能比主div小。不過(guò),還有一種更靈活的方法是遍歷一組元素,然后將高度設(shè)置為***的那個(gè)元素的高度:

  1. var $columns = $('.column'); 
  2. var height = 0
  3. $columns.each(function () { 
  4.   if ($(this).height() > height) { 
  5.     height = $(this).height(); 
  6.   } 
  7. }); 
  8. $columns.height(height); 

如果你希望所有列的高度相同:

  1. var $rows = $('.same-height-columns'); 
  2. $rows.each(function () { 
  3.   $(this).find('.column').height($(this).height()); 
  4. }); 

在新標(biāo)簽頁(yè)/窗口打開外部鏈接

在一個(gè)新的瀏覽器tab或窗口中打開外部鏈接,并確保同一個(gè)來(lái)源的鏈接能在同一個(gè)tab或者窗口中打開:

  1. $('a[href^="http"]').attr('target''_blank'); 
  2. $('a[href^="//"]').attr('target''_blank'); 
  3. $('a[href^="' + window.location.origin + '"]').attr('target''_self'); 

注意:window.location.origin 在IE10中無(wú)效。修復(fù)的時(shí)候要小心這個(gè)問(wèn)題。

通過(guò)文本查找元素

通過(guò)使用jQuery中的contains() 選擇器,你可以找到元素內(nèi)容的文本。如果文本不存在,那就隱藏該元素:

  1. var search = $('#search').val(); 
  2. $('div:not(:contains("' + search + '"))').hide(); 

在改變Visibility時(shí)觸發(fā)

當(dāng)用戶不再關(guān)注某個(gè)tab,或重新聚焦原來(lái)的那個(gè)tab上時(shí),觸發(fā)JavaScript:

  1. $(document).on('visibilitychange', function (e) { 
  2.   if (e.target.visibilityState === "visible") { 
  3.     console.log('Tab is now in view!'); 
  4.   } else if (e.target.visibilityState === "hidden") { 
  5.     console.log('Tab is now hidden!'); 
  6.   } 
  7. }); 

AJAX調(diào)用錯(cuò)誤處理

當(dāng)Ajax調(diào)用返回404或500錯(cuò)誤時(shí),就執(zhí)行錯(cuò)誤處理程序。如果沒(méi)有定義處理程序,其他的jQuery代碼或會(huì)就此罷工。定義一個(gè)全局的Ajax錯(cuò)誤處理程序:

  1. $(document).ajaxError(function (e, xhr, settings, error) { 
  2.   console.log(error); 
  3. }); 

鏈?zhǔn)讲寮{(diào)用

jQuery允許“鏈?zhǔn)?rdquo;插件的方法調(diào)用,以減輕反復(fù)查詢DOM并創(chuàng)建多個(gè)jQuery對(duì)象的過(guò)程。比方說(shuō),下面的代碼片段代表了你的插件方法調(diào)用:

  1. $('#elem').show(); 
  2. $('#elem').html('bla'); 
  3. $('#elem').otherStuff(); 

通過(guò)使用鏈?zhǔn)剑梢源蟠蟾纳疲?/p>

  1. $('#elem'
  2.   .show() 
  3.   .html('bla'
  4.   .otherStuff(); 

還有一種方法是在(前綴$)變量中高速緩存元素:

  1. var $elem = $('#elem'); 
  2. $elem.hide(); 
  3. $elem.html('bla'); 
  4. $elem.otherStuff(); 

鏈?zhǔn)胶透咚倬彺娴姆椒ǘ际莏Query中可以讓代碼變得更短和更快的代***做法。

譯文鏈接:http://www.codeceo.com/article/15-jquery-tips.html
英文原文:jQuery Tips Everyone Should Know

 

責(zé)任編輯:王雪燕 來(lái)源: 碼農(nóng)網(wǎng)
相關(guān)推薦

2013-06-03 11:24:45

程序調(diào)試Java

2018-11-14 10:00:07

程序員開發(fā)技巧Git

2015-11-05 09:19:12

程序員jQuery技巧

2018-05-08 15:30:46

程序員代碼框架

2024-04-24 14:52:26

JavaScriptWeb 開發(fā)

2013-12-02 10:10:35

Python工具庫(kù)

2016-01-18 11:03:58

程序員搜索技巧

2018-09-20 17:05:01

前端程序員JavaScript

2024-05-06 00:00:00

2015-03-24 13:31:06

2022-05-31 09:09:10

vuex技巧前端

2020-04-10 16:35:58

GitHub數(shù)據(jù)網(wǎng)站

2019-07-19 09:21:54

Java開源庫(kù)程序員

2018-03-07 12:57:53

2012-02-28 10:52:13

2023-03-28 23:08:18

Bash編碼Shell

2020-11-11 08:22:40

前端開發(fā)JavaScript

2022-06-02 15:37:58

Web前端開發(fā)

2014-09-26 10:13:32

程序員秘密規(guī)則

2022-09-11 15:20:05

程序員命令開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

99这里都是精品| 亚洲精品www久久久久久广东| 亚洲综合中文字幕在线| 美女100%一区| 一区二区三区免费| 国产一区一区三区| 影音先锋日韩在线| 欧美高清性猛交| 麻豆理论在线观看| 黑丝美女久久久| 97视频在线| 国产精品18久久久久久久久 | 91超碰在线| 婷婷中文字幕综合| 青青在线视频免费| 国产成人一区在线| 欧美精品一区二区视频 | 91福利精品在线观看| 精品视频在线免费看| 国产女主播在线观看| 国产另类ts人妖一区二区| 激情小说网站亚洲综合网| 久久成人福利| 欧美成人h版在线观看| 最新日韩一区| 亚洲片av在线| 女海盗2成人h版中文字幕| 欧美精品久久久久久久多人混战| 在线免费观看av网站| 一区二区成人在线观看| 成人免费淫片| 国产精品女主播av| 欧美老熟妇喷水| 99久久久无码国产精品| 男女猛烈激情xx00免费视频| 国产河南妇女毛片精品久久久| 日韩精品福利视频| 丝瓜av网站精品一区二区| 久久精品日产第一区二区三区精品版| 欧美三级视频| 国产高清一区视频| 在线日本成人| 欧美激情视频一区二区三区| 久久xxxx精品视频| 欧美日韩国产精品一区二区| 午夜亚洲伦理| 亚洲高清在线观看一区| 久久99精品久久久| 日韩在线视频在线| 91美女片黄在线观看91美女| 粗暴91大变态调教| 国产精品嫩草影院com| 成人黄色电影在线| 黄色成人在线免费| aiai在线| 亚洲国产成人精品久久| 亚洲同志男男gay1069网站| 伊人伊成久久人综合网小说| 成人豆花视频| 国产成人在线播放| 欧美一区综合| 亚洲精品中文字幕在线| 成人一二三区视频| 国产freexxxx性播放麻豆| 久久午夜免费电影| 亚色视频在线观看| 91久久精品午夜一区二区| a天堂在线资源| 日韩成人久久久| 日本成人精品| 亚洲aa在线观看| 另类的小说在线视频另类成人小视频在线 | 欧美国产欧美综合| 在线观看视频免费| 欧美日韩精品欧美日韩精品| 欧美人动性xxxxz0oz| 在线精品91av| 欧美一区二区三区激情视频| 成人黄色av免费在线观看| 久久久久久一区二区| 18视频在线观看娇喘| 中文字幕va一区二区三区| 日本一二三区在线视频| 337p日本欧洲亚洲大胆精品 | 一区二区免费在线播放| 第三区美女视频在线| 亚洲精品日韩久久久| av自拍一区| 精品无人区一区二区三区| 国产成人av自拍| 美女黄视频在线播放| 亚洲国产精品久久久久秋霞蜜臀| 91亚洲无吗| 欧美精品一区二区三区在线看午夜 | 欧美日韩国产高清一区二区三区| 日韩电影网站| 国产精品精品久久久久久| 日韩精品欧美成人高清一区二区| 黄色片视频在线免费观看| 欧美日韩国产精品一区| 另类图片综合电影| 欧美中文字幕在线观看| 乱一区二区av| 超碰在线中文| 国产亚洲人成a一在线v站| 天天射天天综合网| 波多野结衣家庭教师在线播放| 狠狠色香婷婷久久亚洲精品| 伊人久久视频| 粉嫩精品一区二区三区在线观看| 成人av在线看| bbbbbbbbbbb在线视频| 久久久亚洲精品视频| 麻豆国产欧美日韩综合精品二区| 视频免费观看| 鲁一鲁一鲁一鲁一澡| 一本久久综合亚洲鲁鲁五月天| 国产69精品久久久久9999人| 国产乱码精品一区二区三区卡 | 亚洲女人被黑人巨大进入| 日韩理论电影院| 黄色片网址在线观看| 日韩午夜av一区| 日韩www.| 99热这里只有精品在线播放| 亚洲精品天天看| 在线看片一区| 美女黄视频在线播放| 久久久久久久网站| 成人在线视频首页| av大全在线| 国产精品裸体一区二区三区| 亚洲精品国产品国语在线app| 免费在线观看一区| 日韩国产美国| 欧美精品一二三区| 综合激情视频| 黄动漫在线观看| 4444欧美成人kkkk| 成人sese在线| 深夜福利视频一区二区| 欧美美乳视频网站在线观看| 日本久久一区二区| 一区二区日韩欧美| 亚洲裸体视频| 国产成人综合精品| 国产欧美视频一区二区| 成人1区2区| 免费极品av一视觉盛宴| 亚洲成人教育av| 久久亚洲一区| 国产区在线看| 欧美日韩精品免费看| 欧美裸体bbwbbwbbw| 天天操综合网| 蜜桃视频在线观看网站| 91免费在线视频网站| 大桥未久av一区二区三区| 欧美一区电影| a√免费观看在线网址www| 97人人模人人爽人人喊中文字| 2020国产精品| **爰片久久毛片| 久久国产精品国产精品| 97精品欧美一区二区三区| 国产精品免费免费| 亚洲黄页网站| 蜜臀在线观看| 亚洲在线观看视频网站| 日本精品一区二区三区四区的功能| 国产精品久久久久久影院8一贰佰 国产精品久久久久久麻豆一区软件 | 精品人妻一区二区三区四区在线| 国产午夜精品视频| 风间由美一区二区三区在线观看| 色猫猫成人app| 黄色片视频在线播放| 欧美不卡视频一区发布| 国产欧美一区二区三区在线看蜜臀 | 国产欧美日韩专区发布| 亚洲国产精品一区二区久久恐怖片 | 一区二区在线高清视频| 亚洲国产99精品国自产| 国产成人综合自拍| 日韩视频1区| 全部孕妇毛片丰满孕妇孕| 亚洲一区中文字幕在线观看| 欧美乱妇一区二区三区不卡视频| 久久亚洲精品伦理| 写真福利精品福利在线观看| 精品免费国产一区二区| 欧美中在线观看| 在线视频一区二区免费| 日韩成人伦理电影在线观看| 久久精品97| 超碰在线公开超碰在线| 农村寡妇一区二区三区| 亚洲天堂成人在线| 一区二区三区高清在线| 亚洲中字黄色| 超碰精品在线观看|