bsSelector.js(OctoberSky.js)
Upcoming SlideShare
Loading in...5
×

Like this? Share it with your network

Share

bsSelector.js(OctoberSky.js)

  • 982 views
Uploaded on

bsSelector ...

bsSelector
Beyond the Sizzle.js.
Fastest pure-JavaScript CSS DOM Selector engine.

More in: Software
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Be the first to comment
No Downloads

Views

Total Views
982
On Slideshare
978
From Embeds
4
Number of Embeds
2

Actions

Shares
Downloads
5
Comments
0
Likes
4

Embeds 4

https://twitter.com 2
http://www.slideee.com 2

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
    No notes for slide
  • http://jsperf.com/jsconf-id-class-name-tag

  • http://jsperf.com/jsconf-id-class-name-tag/2

  • http://jsperf.com/jsconf-function-vs-non-function
  • http://jsperf.com/jsconf-array-prototype-foreach
  • http://jsperf.com/jsconf-native-method-function-prototype-bind

Transcript

  • 1. bsSelector.js
  • 2. PAEK, Seung-Hyun - projectBS core committer - SHOU Communications
  • 3. projectBS
  • 4. projectBS bsJS
  • 5. bsJS var color = bs.Dom('#domID') .S('border-radius', 5, '@width', 100, 'color', '#fff'); console.log(color) // "#fff“ var color = $('#domID').css({ 'borderRadius' : 5, 'WebkitBorderRadius' : 5, 'MozBorderRadius': 5 }) .attr('width', 100) .css('color'); console.log(color) // "#fff"
  • 6. 'bsJS 에 독자적인 셀렉터를 갖고싶은 데..'
  • 7. ‘승현이 니가 만들 면 되겠네~!!'
  • 8. bsSelector
  • 9. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 10. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 11. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 12. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 13. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 14. Selector process query의 tokenizer 요소 선택 요소 순환 요소 판정 결과 반환
  • 15. query = 'ul.toc li.tocline2‘; tokens = ['ul', '.toc', ' ', 'li', ‘.tocline2‘]; if(tokens[i].charAt(0) == '#') document.getElementById(query); else if(tokens[i].charAt(0) == '.') document.getElementByClassName(query); else document.getElementsByTagName('*');
  • 16. ‘CSS2 spec 은 기본 아냐?'
  • 17. ‘CSS3 spec 도 하는 김에 하지?'
  • 18. ‘CSS4 spec 도 &^&&^%&%'
  • 19. 일단 완성
  • 20. Sizzle speed
  • 21. jsPerf.com
  • 22. getElementById getElementsByTagName getElementsByClassName getElementsByName querySelectorAll
  • 23. ID TAG CLASS NAME 2,096,567 1,876,875 1,841,273 1,575,123 17,090,351 8,920,145 8,285,463 8,031,034 19,384,745 16,661,973 17,559,678 19,073,485
  • 24. ID TAG CLASS 124,963 126,480 106,504 1,091,549 222,199 210,918 2,020,367 321,119 339,747
  • 25. 상황은 조금 나아 졌지만… 다음은???
  • 26. JavaScript는 인터프리터 언어
  • 27. 인터프리터?
  • 28. 함수 호출을 최소화
  • 29. 함수 호출을 최소화 한다
  • 30. 함수 호출을 최소화 한다 function Non function 16,830 54,080 49,063 49,436 51,524 52,066
  • 31. 네이티브메서드 안심하지 말자
  • 32. 네이티브메서드라고 안심하지 말자
  • 33. 네이티브메서드라고 안심하지 말자 forEach for() 300 879 658 2,851 142 4,229
  • 34. 네이티브메서드라고 안심하지 말자
  • 35. 네이티브메서드라고 안심하지 말자 Function.bind obj.add() 39,188,564 79,601,156 658 2851 5,125,064 473,773,657
  • 36. LinkedList getElementsByTagName getElementsByClassName
  • 37. var els = document.getElementByTagName(‘div’); console.log(els.length); var newEl = document.createElement(‘div’); document.body.appendChild(newEl); console.log(els.length);
  • 38. 반복의 제거
  • 39. div P[0] P[1] P[2]
  • 40. element.childNodes; children.nodeType == 1; VS element.children
  • 41. 이런 사실들과 알고리즘등을 고려하면서 재작성
  • 42. 이런 사실들과 알고리즘등을 고려하면서 재작성
  • 43. Sizzle Mootools-slick bsSelector 함수개수 : 140 93 13 라인수 : 1,214 2,037 305 용량 : 60,335 37,935 13,485
  • 44. 그 결과
  • 45. Chrome
  • 46. IE
  • 47. 감사합니다. ProjectBS https://www.facebook.com/groups/bs5js/ github bsJS http://ligo.kr/i7 github bsSelector http://ligo.kr/o8