Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
使用 jQuery 的小技巧
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
aco wang
June 15, 2012
Programming
140
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
使用 jQuery 的小技巧
2012-06-11
aco wang
June 15, 2012
More Decks by aco wang
See All by aco wang
Rich Snippets
acowang
0
67
SEO 入門
acowang
0
56
網頁介面設計模式 - 送出邀約
acowang
1
330
Experience
acowang
0
83
洞察,開啟創新
acowang
0
49
如何把使用者經驗「做」出來
acowang
0
270
Other Decks in Programming
See All in Programming
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
530
ECSアプリログをFireLensでコスト削減しようとしたけど諦めた話 in Fargate×Node.js
akihisaikeda
2
4k
OSもどきOS
arkw
0
470
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
120
Oxlintのカスタムルールの現況
syumai
6
1k
RTSPクライアントを自作してみた話
simotin13
0
520
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
1.9k
Vite+ Unified Toolchain for the Web
naokihaba
0
230
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
Dataformのリポジトリを立ち上げるときにまずやること / dataform-day0-2026
snhryt
0
140
AI駆動開発で崩れていくコードベースを立て直す
kyoko_nr_nr
1
450
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
1.9k
Featured
See All Featured
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
600
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Facilitating Awesome Meetings
lara
57
7k
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
310
WCS-LA-2024
lcolladotor
0
620
Scaling GitHub
holman
464
140k
Crafting Experiences
bethany
1
170
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Google's AI Overviews - The New Search
badams
0
1k
Transcript
使用 jQuery 的小技巧 aco 2012-06-11
Selectors
儘量使用 ID Selector • jQuery中最快的 Selector 是 ID Selector –
$(‟#someId‟) • 因為和 JavaScript 的原生函數 getElementById() 對應 • 從 ID Selector 開始繼承 – $(„#traffic_light input‟); <ul id=”traffic_light”> <li><input type=”radio” name=”light” value=”red” /> 紅色</li> <li><input type=”radio” name=”light” value=”yellow” /> 黃色</li> <li><input type=”radio” name=”light” value=”green” /> 綠色</li> </ul>
Tag Selector 和 Class Selector • 第二快的選擇器是 Tag Seletor –
$(‟head‟) • 因為和 JavaScript 的 getElementsByTagName() 對應 • 使用 Class Selector 搭配 Tag – $(„head.someClass‟) – $('div#someId‟) • 使用屬性選擇器,也可以使用 Tag 來修飾 – $('div[align=“left”]‟)
使用相關的子查詢 • 使用 children(), find(), filter() 等來進行子查詢 – $(„p‟).filter(„.highlight‟); •
使用子查詢相對較快速,ex: $parent.find(children),其 中的 $parent 已被 cache 住 • 使用 find() 取代 context $('.testdiv', '#pageBody'); $('#pageBody').find('.testdiv');
DOM
使用變數暫存 Select 後的 Object • 可以減少對 DOM 的尋訪 for (i
= 0; i < 1000; i++) { $('.myList‟).append('This is list item' + i); } var myList = $('.myList'); for (i = 0; i < 1000; i++) { myList.append('This is list item' + i); }
減少對 DOM 直接的操作 • 直接的DOM操作速度相對較慢 var myList = $('#myList'); for
(i=0; i<1000; i++){ myList.append('This is list item ' + i); } var myList = $('.myList'), myListItems = ''; for (i=0; i<1000; i++) { myListItems += '<li>This is list item ' + i + '</li>'; } myList.html(myListItems);
適當的使用鏈接 (Chaining) • 可以減少對 DOM Tree 的尋訪和程式碼的數量 var div =
$(„div‟), tempDiv; tempDiv = div.filter(„:first‟); tempDiv.css(„css‟, „red‟); tempDiv.attr(„name‟, „hello‟); $(„div‟).filter(„:first‟) .css(„color‟, „red‟) .attr(„name‟, „hello‟);
ready 與 load • $(document).ready 可以在 DOM 載入完成後再執行,但 如果要在完全載入完成後再執行的話,可使用 $(window).load
$(document).ready(function (){ // your code }); $(function (){ // your code });
this v.s $(this)
this • this,取得當前的元素 $('#textbox').hover( function() { this.title = 'Test'; }
}
$(this) • $(this),當前元素被 jQuery 處理的對象 $('#textbox').hover( function() { $(this).attr('title', 'Test');
} }
this v.s $(this) • 一般來說,在程式碼中盡量使用 $(this) ,可以讓程式碼 更有規範,在 jQuery 的函數也就可以直接使用,ex:
$(this).children() • $this = $(this);
Others
將程式碼寫成 jQuery Plugin • 如果要花一定得時間去開發一段 jQuery 程式碼,可以考慮將相 關的程式碼變成 Plugin •
能夠重用(Reuse)程式碼,並且能夠有效的組織程式碼 $(function(){ $.fn.yourPluginName = function(){ // Your code }; });
處理相鄰元素 $('#nav li').click(function(){ $('#nav li').removeClass('active'); $(this).addClass('active'); }); $('#nav li').click(function(){ $(this).addClass('active')
.siblings() .removeClass('active'); });
在 .css() 中傳入 Map $('button').on('click', function(){ box.css('font-size', '+=5') .css('color', 'white');
}); $('button').on('click', function(){ box.css({ 'fontSize': '+=5', 'color': 'white' }); });
JavaScript 原生函數相對較快 • for v.s each • createElement(„div‟) v.s $(<div></div>)
• this.id v.s $(this).attr('id')
判斷頁面是否太過複雜 • console.log( $('*').length ); • 返回的數值越小,表示網頁載入的速度越快,假如數值愈 大,可以考慮刪除無用或多餘的元素來優化程式碼
考慮未支援 JavaScript 的網頁 • 透過增加 Class 的方式將相關的元素隱藏或顯示 /* In JS
*/ $('.somthing').addClass(‟hideSomething'); /* In CSS */ .hideSomething {display:none;}
Thank You