'Language/jQuery'에 해당되는 글 29건

  1. 2016.12.15 jQuery Plugin - Plugin 작성 가이드
  2. 2016.12.15 jQuery:$.extend() 와 $.fn.extend()
  3. 2014.12.10 jQuery Mask Plugin
  4. 2014.12.08 jQuery checkbox 컨트롤
  5. 2014.11.20 jQuery grid - jqGrid
  6. 2014.11.20 jQuery BlockUI Plugin
  7. 2014.11.18 jquery ui plug-in
  8. 2014.11.18 jqury tools
  9. 2014.11.18 jquery timer plug-in
  10. 2014.11.18 jquery selectbox

jQuery Plugin - Plugin 작성 가이드

Language/jQuery 2016. 12. 15. 16:35

jQuery plugin이란 것은

 

이미 instance화 되어진 object인 jQuery object를 확장하여 새로운 function을 만들어서 사용할 수 있게 하는 것을 의미합니다.

 

이전 강좌에서 배웠듯이 간단하게 instance화된 새로운 함수 명에 새로운 함수를 작성하면 된다고 볼 수 있다.

 

하지만 jQuery object의 강점중에 하나인 selector로 반환되어져오는 jQuery object를 그대로 사용할 수 있는 형태여야 할 것이다.

 

그래서 미리 만들어진 방법인 $.fn 이라는 namespace밑에 확장해주면 원하는 결과를 얻을 수 있다.

 

이렇게 보면 jQuery plugin의 작성이라는 건 굉장히 단순해 보인다. 실제로도 그렇다.


하지만 특정 plugin을 작성하려면 많은 methods, event procedures 그리고 속성 등을 사용할 수 있어야 편리할 것이다.

 

그래서 jQuery org에서 말하는 plugin 작성법을 기준으로 몇가지를 숙지해 두는 편이 나은 방법인 것과 공유되질 수있는 방법론이 될 것이다.

 

1. $.fn을 확장하면 $ jQuery object를 활용하여 사용할 수 있는 plugin 작성가능하고 $.fn은 jQuery effin'이라고 읽어라는 군요. 제이쿼리 에핀 이렇게 읽으면 되는 건가?(영어가 편한 언어가 아니라. 아픔이 큽니다.)

 

 

2. 외부 코드와 분리해주시기 위해서 self-invating function을 이용하여 작성하자.

 

 

3. method의 호출 결과로 반드시 특정 object나 value를 반환해주는 것이 아니라면(왠만하면 그러지 않는 것이 좋을 것다.) jQuery에 chainability(사전에도 없는 말이다.
   굳이 한글로 바꾸자면 연쇄적으로 내지는 연속적으로 호출가능한 형태)를 유지해주자.

 

 

4. 동작에 필요한 defaults 값들을 object정의하고 외부에서 받아올 options object을 받아서 $.extend()로 확장하여 사용한다.

 

 

5. 하나의 plugin이라도 수많은 methods를 다른 함수로 일일히 작성하지 말고 하나의 plugin함수 안에서 paramter를 받아서 내부에서 분기하도록 하자.

 

 

6. bind 등(애매한 표현 등... 하하 이벤트에 procedure를 붙이는 방법이 다른 좋은 방법들과 이슈가 되는 많다고 하니 이렇게 애매하게 표현하는게 상책이죠.)을 통해서 event procedure를 호출하려고 할때에 다른 plugin과 구분하거나 한번에 unbind하기 위해서라도 plugin이름을 활용하여 명명하자.

 

 

7. 일반적으로 object의 속성과 비교하면 상이한 점이 꽤나 있다.
   하지만 이 instance화되어져 있는 jQuery의 plugin으로서 마찬가지 instance화되어져 있는 속성이라는 것이 각 개체의 특정 값을 유지하거나 공유하기 위해서라면
   이걸 jQuery에서는 data라고 하고 data메서드를 활용하여 작성한다.
   여기서 마찬가지 하나 data메서드, 결국 하나의 data라는 object인데 그 하위에 plugin과 같은 이름 명명하고 그 하위에  값이나 개체의 형태로 data안에 해당 plugin의 속성을 작성해준다.


위의 방법이 반드시 강제성을 띠는 것은 아니다. 단지 가이드 라인이라고 해야할 것이다.


필요하고 더 나은 방법이 있다면 다른 방식으로 구현하고 그 방법이 실제로 더 나은 방벙이라면 역으로 제시하여 새로운 가이드가 만들어질 수도 있을 것이다.

 

이제 위의 항목들을 하나 하나 살펴보도록 하자.

 

 

1. $.fn을 확장하면 $ jQuery object를 활용하여 사용할 수 있는 plugin 작성가능하고 $.fn은 jQuery effin'이라고 읽어라는 군요. 제이쿼리 에핀 이렇게 읽으면 되는 건가?(영어가 편한 언어가 아니라. 아픔이 큽니다.)

01.<html>
02.<head>
03.<title>Javascript Sample Page - jQuery plugin basic</title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06./*
07.가장 기본적인 형태의 jQuery plugin으로 jQuery instance의 $.fn을 확장하면 jQuery object를 확장하여 plugin으로 사용할 수 있다.
08.*/
09.$.fn.GetInnerText = function () {
10.this.each(function () { alert($(this).text()); });
11.}
12.$(document).ready(
13.function () { $(".title").GetInnerText(); }
14.)
15.</script>
16.</head>
17.<body>
18.<table>
19.<tr>
20.<td class="title">제목</td>
21.<td>진달래</td>
22.</tr>
23.<tr>
24.<td class="title">시인</td>
25.<td>김소월</td>
26.</tr>
27.</table>
28.</body>
29.</html>


 

 


2. 외부 코드와 분리해주시기 위해서 self-invating function을 이용하여 작성하자.

 

01.<html>
02.<head>
03.<title>Javascript Sample Page - jQuery plugin standard</title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06./*
07.좀 더 복잡한 형태의 jQuery plugin 으로 사용되면서는 private function과 private 변수의 사용이 불가피해진다.
08.그러므로 다른 global 코드와 이름 중복으로 발생할 문제를 해결하기 위해서 jQuery를 parameter로 하는 self-invacation function을 사용해줍니다.
09.*/
10.(
11.function ($) {
12.$.fn.GetInnerText = function () {
13.this.each(function () { alert($(this).text()); });
14.}
15.}
16.)($)
17.$(document).ready(
18.function () { $(".title").GetInnerText(); }
19.)
20.</script>
21.</head>
22.<body>
23.<table>
24.<tr>
25.<td class="title">제목</td>
26.<td>진달래</td>
27.</tr>
28.<tr>
29.<td class="title">시인</td>
30.<td>김소월</td>
31.</tr>
32.</table>
33.</body>
34.</html>

 


자 그러므로 가장 단순한 형태의 jQuery Plugin 작성형태라고 하면 "(function ($){ $.fn.myplugin = function () { } })($)"이 될 것이다.

 

 

3. method의 호출 결과로 반드시 특정 object나 value를 반환해주는 것이 아니라면(왠만하면 그러지 않는 것이 좋을 것다.) jQuery에 chainability(사전에도 없는 말이다.
   굳이 한글로 바꾸자면 연쇄적으로 내지는 연속적으로 호출가능한 형태)를 유지해주자.

 

01.<html>
02.<head>
03.<title>Javascript Sample Page - Chainability 1 </title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06./*
07.예제에서 파악할 수 있듯이 기 구현되어있는 대부분의 jQuery의 function은 jQuery개체를 최종적으로 계속 반환함으로써 연쇄적인 호출이 가능한 형태로 구현되어져 있습니다.
08.*/
09.(
10.function ($) {
11.$.fn.GetInnerText = function () {
12.this.each(function () { alert($(this).text()); });
13.}
14.}
15.)($)
16.$(document).ready(
17.function () {
18.$(".title").css("background-color""#eeeeee").GetInnerText();
19.$(".title").GetInnerText().css("background-color""#eeeeee"); // css method 에러 발생
20.}
21.)
22.</script>
23.</head>
24.<body>
25.<table>
26.<tr>
27.<td class="title">제목</td>
28.<td>진달래</td>
29.</tr>
30.<tr>
31.<td class="title">시인</td>
32.<td>김소월</td>
33.</tr>
34.</table>
35.</body>
36.</html>

 

 

 

 

그럼 chainability하게 작성하는 방법에 관해서 알아보자.

 

01.<html>
02.<head>
03.<title>Javascript Sample Page - Chainability 2 </title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06./*
07.chainability를 유지해주기. chainability(사전에도 없는 걸 보면 지어낸 말이거나 아니면 신조어일까요?)
08.*/
09.(
10.function ($) {
11.$.fn.GetInnerText = function () {
12.return this.each(function () { alert($(this).text()); });
13.}
14.}
15.)($)
16.$(document).ready(
17.function () {
18.$(".title").GetInnerText().css("background-color""#eeeeee");
19.//$("td").each(function () {$(this).width();});
20.}
21.)
22.</script>
23.</head>
24.<body>
25.<table>
26.<tr>
27.<td class="title">제목</td>
28.<td>진달래</td>
29.</tr>
30.<tr>
31.<td class="title">시인</td>
32.<td>김소월</td>
33.</tr>
34.</table>
35.</body>
36.</html>

 

 

 

 

적절한 예제라고 보기에는 억지가 많지만 작성법만을 보도록 하자.

결국 마지막에 instance화된 자신의 object를 의미하는 this를 반환하면 된다.

 

 


4. 동작에 필요한 defaults 값들을 object정의하고 외부에서 받아올 options object을 받아서 $.extend()로 확장하여 사용한다.

 

01.<html>
02.<head>
03.<title>Javascript Sample Page - defaults and options with $.extend </title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06.//$.extend를 이용하여 좀 더 사용하기 편리한 parameters와 default값들을 지정하기
07.(
08.function ($) {
09.// plugin내에서 사용할 기본값으로 setting된 object를 미리 만들어 둡니다.
10.StylingDefaults = { font: "맑은 고딕", foreColor: "blue", backColor: "#eeeeee" };
11. 
12.$.fn.MyCompanyStyling = function (options) {
13.this.each(
14.//function (options) { //이것은 each라는 메서드가 넘겨주는 첫번째 parameter로 options은 each의 각 index가 넘어옵니다.
15.function () {
16.// plugin 내의 기본값을 가진 object를 기준으로 받은 options을 덮어 씁니다.
17.$.extend(StylingDefaults, options);
18.//$.extend(options, StylingDefaults); // 이렇게 하면 받은 options 값을 기준으로 원래 기본값을 덮어쓰면서 기본값이 적용됩니다.
19. 
20.//원하는 코드를 작성합니다.
21.$(this).css("font-family", StylingDefaults.font).css("color", StylingDefaults.foreColor).css("background-color", StylingDefaults.backColor);
22.}
23.);
24.return this;
25.}
26.}
27.)($)
28. 
29.$(document).ready(
30.function () {
31.$(".title").MyCompanyStyling({ foreColor:"red" });
32.}
33.)
34.</script>
35.</head>
36.<body>
37.<table>
38.<tr>
39.<td class="title">제목</td>
40.<td>진달래</td>
41.</tr>
42.<tr>
43.<td class="title">시인</td>
44.<td>김소월</td>
45.</tr>
46.</table>
47.</body>
48.</html>

 


 

 

 


5. 하나의 plugin이라도 수많은 methods를 다른 함수로 일일히 작성하지 말고 하나의 plugin함수 안에서 paramter를 받아서 내부에서 분기하도록 하자.

 

01.<html>
02.<head>
03.<title>Javascript Sample Page - Methods Namespacing</title>
04.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
05.<script language="javascript" type="text/javascript">
06.// 근본적으로 jQuery plugin이라는 것이 fn이라는 namespace 아래에 자리 잡는 것입니다.
07.// 그래서 plugin 하나 하나가 다수의 method를 만들면 결국 plugin 몇 개만 써도 엄청난 수의 method가 fn밑에 자리 잡게 되고
08.// 결국 어떤 plugin의 메서드인지 뭐하는 method인지 헤갈리게 될 가능성이 높을 것 같습니다.
09.// 그래서 jQuery org는 method이름을 paramter의 형태로 받아서 해당 plugin 내부에서 분기하라고 가이드 하고 있습니다.
10.(
11.function ($) {
12. 
13.// 사용할 method 선언부
14.var actions = {
15.TitleStyling: function (options) {
16.Defaults = { font: "맑은 고딕", foreColor: "blue", backColor: "#eeeeee" };
17.this.each(
18.function () {
19.$.extend(Defaults, options);
20.$(this).css("font-family", Defaults.font).css("color", Defaults.foreColor).css("background-color", Defaults.backColor);
21.}
22.);
23.return this;
24.},
25.ValueCellStyling: function () { this.each(function () { $(this).css("font-weight""normal"); }); returnthis; }
26.}
27. 
28.// 각각의 sub procedure를 호출해주는 main
29.$.fn.MyCompanyStyling = function (action) {
30.if (actions[action])
31.return actions[action].apply(this, Array.prototype.slice.call(arguments, 1));
32.else
33.return actions.TitleStyling.apply(this, arguments);
34.}
35.}
36.)($)
37. 
38.$(document).ready(
39.function () {
40.$(".title").MyCompanyStyling({ foreColor: "red" });
41.$(".cellcontent").MyCompanyStyling("ValueCellStyling");
42.}
43.)
44.</script>
45.</head>
46.<body>
47.<table>
48.<tr>
49.<td class="title">제목</td>
50.<td class="cellcontent" style="font-weight:bold">진달래</td>
51.</tr>
52.<tr>
53.<td class="title">시인</td>
54.<td class="cellcontent">김소월</td>
55.</tr>
56.</table>
57.</body>
58.</html>


 

 


6. bind 등(애매한 표현 등... 하하 이벤트에 procedure를 붙이는 방법이 다른 좋은 방법들과 이슈가 되는 많다고 하니 이렇게 애매하게 표현하는게 상책이죠.)을 통해서 event procedure를 호출하려고 할때에 다른 plugin과 구분하거나 한번에 unbind하기 위해서라도 plugin이름을 활용하여 명명하자.

 

01. 
02.<html>
03.<head>
04.<title>Javascript Sample Page - Events Namespacing</title>
05.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
06.<script language="javascript" type="text/javascript">
07.(
08.function ($) {
09.var actions = {
10.// Event Procedure를 각각의 events에 bind해주는 역활의 함수
11.// 일반적으로 jQuery org예제처럼 plugin이 초기화되면 해당 동작을 많이 하므로 init이라는 이름으로 만들고 초기화하면서 bind해주는 경우가 많다.
12.// 본 예제에서는 이해를 돕기 위해 이름을 별나게 작성하였다.
13.AttachEvents: function () {
14.this.each(function () {
15.// 해당 plugin이름으로 하나씩 event bind해준다.
16.$(this).bind('click.myCompanyStyling', displayClickedCoordinate);
17.$(this).bind('mousemove.myCompanyStyling', displayMovingCoordinate);
18.});
19.return this;
20.},
21.// 필요할 경우나 개인적인 의견으로 한 페이지에서 끝나고 다음 페이지로 이동하는 웹페이지의 형태에서 잘 사용하지 않을 것 같으나 소멸자에서 사용이 되어진다.
22.// unbind해주는 method로 소멸자의 경우 일반적으로 destory라는 이름을 많이 사용한다.
23.// 본 예제에서는 이해를 돕기 위해 이름을 별나게 작성하였다.
24.DisattachEvents: function () {
25.// 해당 plugin 이름으로 한번 unbind
26.$(this).unbind('.myCompanyStyling');
27.return this;
28.}
29.}
30.// plugin 내부에 private한 함수들이다.
31.// self-invacation 되어 있으므로 현재 상태로는 외부에서 접근이 불가능한 코드이다.
32.function displayClickedCoordinate(e) {
33.$("#divClickedCoordinate").text('styling clicked coordinate x: ' + e.pageX + ', y: ' + e.pageY);
34.}
35.function displayMovingCoordinate(e) {
36.$("#divMovingCoordinate").text('mouse coordinate x: ' + e.pageX + ', y: ' + e.pageY);
37.}
38.// method로 분기해주는 main procedure
39.$.fn.MyCompanyStyling = function (action) {
40.if (actions[action])
41.return actions[action].apply(this, Array.prototype.slice.call(arguments, 1));
42.else
43.return actions.init.apply(this, arguments);
44.}
45.}
46.)($)
47.$(document).ready(
48.function () {
49.// 위의 plugin의 namespace가 아닌 다른 곳에서의 bind 2가지
50.// 1. window의 mousemove bind
51.$(window).bind('mousemove'function (e) {
52.$("#divGlobalMousePosition").text('mouse coordinate x: ' + e.pageX + ', y: ' + e.pageY);
53.});
54.// 2. plugin과 같은 개체의 같은 event에 bind
55.$('#tableContent').bind('click'function (e) {
56.$("#divClickedCoordinate").text('clicked coordinate x: ' + e.pageX + ', y: ' + e.pageY);
57.});
58.}
59.);
60.</script>
61.</head>
62.<body>
63.<table id="tableContent">
64.<tr>
65.<td class="title">제목</td>
66.<td class="cellcontent" style="font-weight:bold">진달래</td>
67.</tr>
68.<tr>
69.<td class="title">시인</td>
70.<td class="cellcontent">김소월</td>
71.</tr>
72.</table>
73.<div id="divGlobalMousePosition"></div>
74.<div id="divClickedCoordinate"></div>
75.<div id="divMovingCoordinate"></div>
76.<!-- plugin을 통한 이벤트 프로시저 bind -->
77.<input type="button" value="attach events"onclick="javascript:$('#tableContent').MyCompanyStyling('AttachEvents');" />
78.<!-- plugin을 통한 이벤트 프로시저 unbind -->
79.<input type="button" value="disattach events"onclick="javascript:$('#tableContent').MyCompanyStyling('DisattachEvents');" />
80.</body>
81.</html>
82. 

 

 


7. 일반적으로 object의 속성과 비교하면 상이한 점이 꽤나 있다.
   하지만 이 instance화되어져 있는 jQuery의 plugin으로서 마찬가지 instance화되어져 있는 속성이라는 것이 각 개체의 특정 값을 유지하거나 공유하기 위해서라면
   이걸 jQuery에서는 data라고 하고 data메서드를 활용하여 작성한다.
   여기서 마찬가지 하나 data메서드, 결국 하나의 data라는 object인데 그 하위에 plugin과 같은 이름 명명하고 그 하위에  값이나 개체의 형태로 data안에 해당 plugin의 속성을 작성해준다.

 

 

먼저 간단하게 table cell 까만 막대기를 그려주는 jQuery plugin을 작성법대로 기본을 잡아주자.

 

01. 
02.<html>
03.<head>
04.<title>Javascript Sample Page - Events Namespacing</title>
05.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
06.<script language="javascript" type="text/javascript">
07.(
08.function ($) {
09.var methods = {
10.init: function () {
11.this.each(function () {
12.$(this).append($('<div style=\"background-color:black;height:15px;width:100px;\">&nbsp;</div>'));
13.});
14.return this;
15.},
16.}
17.$.fn.RandomBar = function (method) {
18.if (methods[method])
19.return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
20.else
21.return methods.init.apply(this, arguments);
22.}
23.}
24.)($)
25.$(document).ready(
26.function () {
27.$(".sample tr td").RandomBar();
28.}
29.);
30.</script>
31.</head>
32.<body>
33.<table class="sample">
34.<tr>
35.<td></td>
36.</tr>
37.<tr>
38.<td></td>
39.</tr>
40.<tr>
41.<td></td>
42.</tr>
43.<tr>
44.<td></td>
45.</tr>
46.</table>
47.</body>
48.</html>
49. 

 

 

 

자! 이제 랜덤한 길이로 보이도록 하자.
(참고로 차분히 이해를 돕기 위해서 step별로 하는 것이지 절대로 원고 불리기가 아닙니다. ㅡㅡ;)

 

01. 
02.<html>
03.<head>
04.<title>Javascript Sample Page - Events Namespacing</title>
05.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
06.<script language="javascript" type="text/javascript">
07.(
08.function ($) {
09.var methods = {
10.init: function () {
11.this.each(function () {
12.$(this).append($('<div style=\"background-color:black;height:15px;width:' + Math.floor(Math.random()*1001).toString() + 'px;\">&nbsp;</div>'));
13.});
14.return this;
15.}
16.}
17.$.fn.RandomBar = function (method) {
18.if (methods[method])
19.return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
20.else
21.return methods.init.apply(this, arguments);
22.}
23.}
24.)($)
25.$(document).ready(
26.function () {
27.$(".sample tr td").RandomBar();
28.}
29.);
30.</script>
31.</head>
32.<body>
33.<table class="sample">
34.<tr>
35.<td></td>
36.</tr>
37.<tr>
38.<td></td>
39.</tr>
40.<tr>
41.<td></td>
42.</tr>
43.<tr>
44.<td></td>
45.</tr>
46.</table>
47.</body>
48.</html>
49. 

 

 

 

자! 그럼 이제 길이과 미리 정해진 색상과 라벨을 할당하고 이에 관한 속성을 만들어 보도록 하겠습니다.

 

01. 
02.<html>
03.<head>
04.<title>Javascript Sample Page - Events Namespacing</title>
05.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
06.<script language="javascript" type="text/javascript">
07.(
08.function ($) {
09.// private variables
10.var barnames = ['사랑''평온''행복']
11.var barcolors = ['red''blue''gray''black''yellow']
12.var methods = {
13.init: function () {
14.this.each(function () {
15.// set data
16.$(this).data('RandomBar', {
17.name: barnames[Math.floor(Math.random() * 3) - 1],
18.barcolor: barcolors[Math.floor(Math.random() * 6) - 1],
19.barlength: Math.floor(Math.random() * 1001).toString() + 'px'
20.});
21.// get data
22.$(this).append($('<div style=\"background-color:' + $(this).data().RandomBar.barcolor + ';height:15px;width:' + $(this).data().RandomBar.barlength + ';\">&nbsp;</div>'));
23.});
24.return this;
25.}
26.}
27. 
28.$.fn.RandomBar = function (method) {
29.if (methods[method])
30.return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
31.else
32.return methods.init.apply(this, arguments);
33.}
34.}
35.)($)
36.$(document).ready(
37.function () {
38.$(".sample tr td").RandomBar();
39.}
40.);
41.</script>
42.</head>
43.<body>
44.<table class="sample">
45.<tr>
46.<td></td>
47.</tr>
48.<tr>
49.<td></td>
50.</tr>
51.<tr>
52.<td></td>
53.</tr>
54.<tr>
55.<td></td>
56.</tr>
57.</table>
58.</body>
59.</html>
60. 

 

 

 

이렇게 만들어진 속성에 해당하는 data로 유지된 value를 event procedure에 활용하는 형태로 마무리해보겠습니다.

 

01. 
02.<html>
03.<head>
04.<title>Javascript Sample Page - Events Namespacing</title>
05.<script language="javascript" type="text/javascript" src="jquery-1.6.2.min.js"></script>
06.<script language="javascript" type="text/javascript">
07.(
08.function ($) {
09.// private variables
10.var barnames = ['사랑''평온''행복']
11.var barcolors = ['red''blue''gray''black''yellow']
12.//private event procedure
13.function displayBarInfo() {
14.$(".barinfo").text('이름: ' + $(this).data().RandomBar.name + ', 길이: ' + $(this).data().RandomBar.barlength + ', 색상: ' + $(this).data().RandomBar.barcolor);
15.}
16.function hideBarInfo() {
17.$(".barinfo").text('');
18.}
19.var methods = {
20.init: function () {
21.this.each(function () {
22.// set data
23.$(this).data('RandomBar', {
24.name: barnames[Math.floor(Math.random() * 3)],
25.barcolor: barcolors[Math.floor(Math.random() * 5)],
26.barlength: Math.floor(Math.random() * 1001).toString() + 'px'
27.});
28.// get data
29.$(this).append($('<div style=\"background-color:' + $(this).data().RandomBar.barcolor + ';height:15px;width:' + $(this).data().RandomBar.barlength + ';\">&nbsp;</div>'));
30.// attach event procedure
31.$(this).bind('mouseover.Randombar', displayBarInfo);
32.$(this).bind('mouseout.Randombar', hideBarInfo);
33.});
34.return this;
35.}
36.}
37. 
38.$.fn.RandomBar = function (method) {
39.if (methods[method])
40.return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
41.else
42.return methods.init.apply(this, arguments);
43.}
44.}
45.)($)
46.$(document).ready(
47.function () {
48.$(".sample tr td").RandomBar();
49.}
50.);
51.</script>
52.</head>
53.<body>
54.<!-- 절대 분량을 늘릴려고 줄 수 많이 한 것 아닙니다. 재미있어요. 하하하 -->
55.<table class="sample">
56.<tr>
57.<td></td>
58.</tr>
59.<tr>
60.<td></td>
61.</tr>
62.<tr>
63.<td></td>
64.</tr>
65.<tr>
66.<td></td>
67.</tr>
68.<tr>
69.<td></td>
70.</tr>
71.<tr>
72.<td></td>
73.</tr>
74.<tr>
75.<td></td>
76.</tr>
77.<tr>
78.<td></td>
79.</tr>
80.<tr>
81.<td></td>
82.</tr>
83.<tr>
84.<td></td>
85.</tr>
86.</table>
87.<div class="barinfo"></div>
88.</body>
89.</html>
90. 

 

출처 - http://www.sqler.com/456517

'Language > jQuery' 카테고리의 다른 글

jQuery:$.extend() 와 $.fn.extend()  (0) 2016.12.15
jQuery Mask Plugin  (0) 2014.12.10
jQuery checkbox 컨트롤  (0) 2014.12.08
jQuery grid - jqGrid  (0) 2014.11.20
jQuery BlockUI Plugin  (0) 2014.11.20
:

jQuery:$.extend() 와 $.fn.extend()

Language/jQuery 2016. 12. 15. 16:34

jQuery:$.extend() 와 $.fn.extend() 의 혼동

.extend() 함수를 사용할 때 하나의 인수를 넘기는 것과 두 개 이상의 인수를 넘기는 것에는 아주 큰 차이가 있습니다.

 

.extend() 함수가 하나의 객체를 받을 때

선언된 메소드를 jQuery 나 jQuery.fn (jQuery.prototype, 또는 $.fn 이라고 불리죠.) 에 추가시킵니다.

 

일반적으로 함수를 위해서는 jQuery 객체를 extend 시키고 메소드를 위해서는 jQuery.fn 을 extend 시킵니다. 함수는 DOM 에서 바로 접근이 불가능하고 메소드는 바로 접근이 가능하죠.

 

다음 예제에서 jQuery.fn 또는 jQuery 객체를 extend 시킬 때 부르는 방식이 달라짐을 눈여겨 보시기 바랍니다.

 

  1. $.fn.extend({
  2. myMethod: function(){...}
  3. });
  4. //jQuery("div").myMethod();
  5.  
  6. $.extend({
  7. myMethod2: function(){...}
  8. });
  9. //jQuery.myMethod2(); 

 

 

.extend() 함수가 2개 이상의 객체를 받을 때

일반적으로 알려진 것 처럼 첫 번째 객체와 두 번째 객체를 병합(merge) 합니다.

 

  1. var defaults = { size3 };
  2. var options = { height6 };
  3. var opts = $.extend(defaults, options)
  4. // 'defaults' 가 'options' 에 정의된 메소드와 변수들을 받아옵니다.
  5. // opts == defaults == { size: 3, height: 6 }
  6. // options == { height: 6 };

 

 

만약에 첫 번째 객체가 빈 객체라면 메소드와 변수들을 새로운 객체에 추가시킵니다.

만약 여러 개의 객체들을 단 하나의 객체도 변화시키지 않고 새로운 객체에 만들 때 아주 유용합니다.

 

  1. var opts = $.extend( {}, defaults, options);
  2. // 'opts' 가 'defaults' 와 'options'에 선언된 모든 메소드와 변수들을 받습니다.
  3. // 'defaults' 와 'options' 는 변하지 않습니다.
  4. // opts == { size: 3, height: 6 }
  5. // defaults == { size: 3 };
  6. // options == { height: 6 };


출처 - http://m.blog.naver.com/k_rifle/178134527

'Language > jQuery' 카테고리의 다른 글

jQuery Plugin - Plugin 작성 가이드  (0) 2016.12.15
jQuery Mask Plugin  (0) 2014.12.10
jQuery checkbox 컨트롤  (0) 2014.12.08
jQuery grid - jqGrid  (0) 2014.11.20
jQuery BlockUI Plugin  (0) 2014.11.20
:

jQuery Mask Plugin

Language/jQuery 2014. 12. 10. 10:22

http://plugins.jquery.com/mask/


Documentation

Basic Usage Examples

$(document).ready(function(){
  $('.date').mask('00/00/0000');
  $('.time').mask('00:00:00');
  $('.date_time').mask('00/00/0000 00:00:00');
  $('.cep').mask('00000-000');
  $('.phone').mask('0000-0000');
  $('.phone_with_ddd').mask('(00) 0000-0000');
  $('.phone_us').mask('(000) 000-0000');
  $('.mixed').mask('AAA 000-S0S');
  $('.cpf').mask('000.000.000-00', {reverse: true});
  $('.money').mask('000.000.000.000.000,00', {reverse: true});
  $('.money2').mask("#.##0,00", {reverse: true});
  $('.ip_address').mask('0ZZ.0ZZ.0ZZ.0ZZ', {
    translation: {
      'Z': {
        pattern: /[0-9]/, optional: true
      }
    }
  });
  $('.ip_address').mask('099.099.099.099');
  $('.percent').mask('##0,00%', {reverse: true});
  $('.clear-if-not-match').mask("00/00/0000", {clearIfNotMatch: true});
  $('.placeholder').mask("00/00/0000", {placeholder: "__/__/____"});
  $('.fallback').mask("00r00r0000", {
      translation: {
        'r': {
          pattern: /[\/]/, 
          fallback: '/'
        }, 
        placeholder: "__/__/____"
      }
    });
);

Callback Examples

var options =  { 
  onComplete: function(cep) {
    alert('CEP Completed!:' + cep);
  },
  onKeyPress: function(cep, event, currentField, options){
    console.log('An key was pressed!:', cep, ' event: ', event, 
                'currentField: ', currentField, ' options: ', options);
  },
  onChange: function(cep){
    console.log('cep changed! ', cep);
  },
  onInvalid: function(val, e, f, invalid, options){
    var error = invalid[0];
    console.log ("Digit: ", error.v, " is invalid for the position: ", error.p, ". We expect something like: ", error.e);
  }
};

$('.cep_with_callback').mask('00000-000', options);

On-the-fly mask change

var options =  {onKeyPress: function(cep, e, field, options){
  var masks = ['00000-000', '0-00-00-00'];
    mask = (cep.length>7) ? masks[1] : masks[0];
  $('.crazy_cep').mask(mask, options);
}};

$('.crazy_cep').mask('00000-000', options);

Mask as a function

var SPMaskBehavior = function (val) {
  return val.replace(/\D/g, '').length === 11 ? '(00) 00000-0000' : '(00) 0000-00009';
},
spOptions = {
  onKeyPress: function(val, e, field, options) {
      field.mask(SPMaskBehavior.apply({}, arguments), options);
    }
};

$('.sp_celphones').mask(SPMaskBehavior, spOptions);

Using HTML Notation Exemples

To get your mask applied with the data-mask attribute just use it as the same way you use with the $.mask function. 

<input type="text" name="field-name" data-mask="00/00/0000" />
Activating a reversible mask 

<input type="text" name="field-name" data-mask="00/00/0000" data-mask-reverse="true" />
Using clearIfNotMatch option 

<input type="text" name="field-name" data-mask="00/00/0000" data-mask-clearifnotmatch="true" />

Translation

Teach to jQuery Mask Plugin how to apply your mask: 

// now the digit 0 on your mask pattern will be interpreted 
// as valid characters like 0,1,2,3,4,5,6,7,8,9 and *
$('.your-field').mask('00/00/0000', {'translation': {0: {pattern: /[0-9*]/}}});
By default, jQuery Mask Plugin only reconizes the logical digit A (Numbers and Letters) and S (A-Za-z) but you can extend or modify this behaviour by telling to jQuery Mask Plugin how to interpret those logical digits. 

$('.your-field').mask('AA/SS/YYYY', {'translation': {
                                        A: {pattern: /[A-Za-z0-9]/}, 
                                        S: {pattern: /[A-Za-z]/},  
                                        Y: {pattern: /[0-9]/}
                                      }
                                });
Now jQuery Mask Plugin knows the logic digit Y and you can create your own pattern. 

Optional digits


You can also tell to jQuery Mask which digit is optional, to create a IP mask for example: 

// way 1
$('.ip_address').mask('099.099.099.099');
// way 2
$('.ip_address').mask('0ZZ.0ZZ.0ZZ.0ZZ', {translation:  {'Z': {pattern: /[0-9]/, optional: true}}});
Now, all Z digits in your masks is optional. 

Recursive digits


With jQuery Mask Plugin you can also define recursive patterns inside your mask: 

$('.money_example').mask('#.##0,00', {reverse: true});
With example above the mask will be placed from the right to the left (that's why reverse:true is defined). As soon as you start typing, a "0,00" will be applied followed by repeating recursively the following pattern "#.##". The result could be something like: 1.234.567,890. 

You can also use that kind of feature to define what kind of data could be typed inside of a field:
$('.example').mask('0#');
Now only numbers will be allowed inside your form field. 

Fallback digits

When a user types a invalid char for the current position the plugin will replace it by its fallback instead of erasing them.
$('.field_with_fallback').mask("00r00r0000", {
  translation: {
    'r': {
      pattern: /[\/]/, 
      fallback: '/'
    }, 
    placeholder: "__/__/____"
  }
});

Removing the mask

$('.date').unmask();

Getting the unmasked typed value

$('.date').cleanVal();

Customization

jQuery Mask Plugin has a few default options that you can overwrite as you like:

Field Options

var custom_options = {
  byPassKeys: [8, 9, 37, 38, 39, 40],
  translation: {
                '0': {pattern: /\d/}, 
                '9': {pattern: /\d/, optional: true}, 
                '#': {pattern: /\d/, recursive: true}, 
                'A': {pattern: /[a-zA-Z0-9]/}, 
                'S': {pattern: /[a-zA-Z]/}
            };
};
byPassKeys list of keyboard's keyCode that you want to be ignored when it was pressed. 
translation object with all digits that should be interpreted as a special chars and its regex representation. 

Global Options

// nonInput: elements we consider nonInput
// dataMask: we mask data-mask elements by default
// watchInputs: watch for dynamically added inputs by default
// watchDataMask: by default we disabled the watcher for dynamically added data-mask elements by default (performance reasons)
 $.jMaskGlobals = {
    nonInput: 'td,span,div', 
    dataMask: true, 
    watchInterval: 300,
    watchInputs: true, 
    watchDataMask: false,
    byPassKeys: [9, 16, 17, 18, 36, 37, 38, 39, 40, 91],
    translation: {
      '0': {pattern: /\d/},
      '9': {pattern: /\d/, optional: true},
      '#': {pattern: /\d/, recursive: true},
      'A': {pattern: /[a-zA-Z0-9]/},
      'S': {pattern: /[a-zA-Z]/}
    }
  };


'Language > jQuery' 카테고리의 다른 글

jQuery Plugin - Plugin 작성 가이드  (0) 2016.12.15
jQuery:$.extend() 와 $.fn.extend()  (0) 2016.12.15
jQuery checkbox 컨트롤  (0) 2014.12.08
jQuery grid - jqGrid  (0) 2014.11.20
jQuery BlockUI Plugin  (0) 2014.11.20
:

jQuery checkbox 컨트롤

Language/jQuery 2014. 12. 8. 12:37

checkbox checked 여부 : 

- id로 체크하는 경우

$('input:checkbox[id="checkbox_id"]').is(":checked") == true


- name으로 체크하는 경우

$('input:checkbox[name="checkbox_name"]').is(":checked") == true


- $('input[id="checkbox_id"]') + 옵션 형태로 작성 가능

 $('input[name="checkbox_name"]').is(":checked") 



checkbox 갯수 확인 : 

- 전체 갯수 

$('input:checkbox[id="checkbox_name"]').length 


- 선택된 갯수

$('input:checkbox[id="checkbox_name"]:checked').length 


- 배열을 사용할 경우

$('input:checkbox[id ='checkbox_name[]"]:checked').length

$("input[id ='checkbox_name[]']:checked").length



checkbox checked 처리 :

- 개별

$('input:checkbox[id="checkbox_id"]').attr("checked", true);


- 전체(동일한 id나 name으로 여래개인 경우 전체를 컨트롤 가능)

$('input:checkbox[name="checkbox_name"]').each(function() {

this.checked = true;

});



checkbox value 값 가져오기 :

$('input:checkbox[id="checkbox_id"]').val();

 

 출처 - http://isstory83.tistory.com/112

'Language > jQuery' 카테고리의 다른 글

jQuery:$.extend() 와 $.fn.extend()  (0) 2016.12.15
jQuery Mask Plugin  (0) 2014.12.10
jQuery grid - jqGrid  (0) 2014.11.20
jQuery BlockUI Plugin  (0) 2014.11.20
jquery ui plug-in  (0) 2014.11.18
:

jQuery grid - jqGrid

Language/jQuery 2014. 11. 20. 15:28

http://www.trirand.com/blog/

'Language > jQuery' 카테고리의 다른 글

jQuery Mask Plugin  (0) 2014.12.10
jQuery checkbox 컨트롤  (0) 2014.12.08
jQuery BlockUI Plugin  (0) 2014.11.20
jquery ui plug-in  (0) 2014.11.18
jqury tools  (0) 2014.11.18
:

jQuery BlockUI Plugin

Language/jQuery 2014. 11. 20. 10:35

Overview

The jQuery BlockUI Plugin lets you simulate synchronous behavior when using AJAXwithout locking the browser[1]. When activated, it will prevent user activity with the page (or part of the page) until it is deactivated. BlockUI adds elements to the DOM to give it both the appearance and behavior of blocking user interaction.

Usage is very simple; to block user activity for the page:

$.blockUI();

Blocking with a custom message:

$.blockUI({ message: '<h1><img src="busy.gif" /> Just a moment...</h1>' });

Blocking with custom style:

$.blockUI({ css: { backgroundColor: '#f00', color: '#fff'} });

To unblock the page:

$.unblockUI();

If you want to use the default settings and have the UI blocked for all ajax requests, it's as easy as this:

$(document).ajaxStart($.blockUI).ajaxStop($.unblockUI);



출처 - http://www.malsup.com/jquery/block/

'Language > jQuery' 카테고리의 다른 글

jQuery checkbox 컨트롤  (0) 2014.12.08
jQuery grid - jqGrid  (0) 2014.11.20
jquery ui plug-in  (0) 2014.11.18
jqury tools  (0) 2014.11.18
jquery timer plug-in  (0) 2014.11.18
:

jquery ui plug-in

Language/jQuery 2014. 11. 18. 16:03

http://jqueryui.com/

'Language > jQuery' 카테고리의 다른 글

jQuery grid - jqGrid  (0) 2014.11.20
jQuery BlockUI Plugin  (0) 2014.11.20
jqury tools  (0) 2014.11.18
jquery timer plug-in  (0) 2014.11.18
jquery selectbox  (0) 2014.11.18
:

jqury tools

Language/jQuery 2014. 11. 18. 15:52

http://jquerytools.github.io/demos/

'Language > jQuery' 카테고리의 다른 글

jQuery BlockUI Plugin  (0) 2014.11.20
jquery ui plug-in  (0) 2014.11.18
jquery timer plug-in  (0) 2014.11.18
jquery selectbox  (0) 2014.11.18
jQuery Multiple File Upload Plugin  (0) 2014.11.18
:

jquery timer plug-in

Language/jQuery 2014. 11. 18. 15:47
https://github.com/sloat/timer


'Language > jQuery' 카테고리의 다른 글

jquery ui plug-in  (0) 2014.11.18
jqury tools  (0) 2014.11.18
jquery selectbox  (0) 2014.11.18
jQuery Multiple File Upload Plugin  (0) 2014.11.18
jNotify jQuery Plug-in  (0) 2014.11.18
:

jquery selectbox

Language/jQuery 2014. 11. 18. 15:36

Source code available from GitHub or a Zipped download.

My Select:

My Select 2:

#myselect2 '#myselect2 option 2' (text) : 'myselect2_2' (value) selected

addOption

You can add a single option: $("#myselect").addOption("Value", "Text");,
change the text of an existing option:$("#myselect").addOption("Value", "Text Replacement"); or add
multiple options using a hash:

var myOptions = {
	"Value 1" : "Text 1",
	"Value 2" : "Text 2",
	"Value 3" : "Text 3"
}
$("#myselect2").addOption(myOptions, false); // use true if you want to select the added options 

ajaxAddOption(url[, params, select, fn, args])

Add options via AJAX (page must return valid JSON, sample below):$("#myselect2").ajaxAddOption("ajaxoptions.js");.

Parameters

  • url – Page to get options from (must be valid JSON)
  • params (optional) – Any parameters to send with the request
  • select (optional) – Select the added options, default true
  • fn (optional) – call this function with the select object as param after completion
  • args – (optional) array of arguments to pass onto the function

$("#myselect2").ajaxAddOption("ajaxoptions.js", {}, false, sortoptions, [{"dir":"desc"}]);

function sortoptions(sort)
{
	var $this = $(this);
	// sort
	$this.sortOptions(sort.dir == "asc" ? true : false);
}

removeOption(index/value/regex/array[, selectedOnly])

Remove an option by

- index: $("#myselect2").removeOption(0);

- value: $("#myselect").removeOption("Value");

- regular expression: $("#myselect").removeOption(/^val/i);

- array $("#myselect").removeOption(["myselect_1", "myselect_2"]);

To remove all options, you can do $("#myselect").removeOption(/./);

If you supply a second parameter as a boolean (true, false), then only options that have been selected (and matched) will be removed:$("#myselect2").removeOption("Value 2", true);.

sortOptions([ascending])

Sorting is done as follows: $("#myselect2").sortOptions(false);(descending)
or $("#myselect2").sortOptions(); (ascending)

selectOptions(value[, clear])

Select options by value, using a string as the parameter$("#myselect2").selectOptions("Value 1");, or a regular expression
$("#myselect2").selectOptions(/^val/i);. You can also clear already selected options:
$("#myselect2").selectOptions("Value 2", true);

Originally coded by Mathias Bank, with a modification to allow it to take a regular expression.

copyOptions(to[, which])

You can copy options from one select to another:$("#myselect").copyOptions("#myselect2"); (copy selected options) or
$("#myselect").copyOptions("#myselect2", "all"); (copy all options)

containsOption(value[, fn])

Checks if a select box has an option with the supplied value

Parameters

  • value – Which value to check for. Can be a string or regular expression
    e.g.
    if( $("#myselect").containsOption("val1") ) { ... } or
    if( $("#myselect").containsOption(/^val/i) ) { ... }
  • fn (optional) – Function to apply if an option with the given value is found. Use this if you don’t want to break the chaining
    e.g. $("#myselect").containsOption("val1", copyoption).doSomethingElseWithSelect(); // calls copyoption (user defined function) for any options found, chain is continued

selectedValues()

Returns an array of the values which have been selected.$("#myselect2").selectedValues().

selectedTexts()

Returns an array of the texts which have been selected.$("#myselect2").selectedTexts().

selectedOptions()

Returns a jQuery object with each <option> that has been selected.$("#myselect2").selectedOptions().




출처 http://www.texotela.co.uk/code/jquery/select/#

'Language > jQuery' 카테고리의 다른 글

jqury tools  (0) 2014.11.18
jquery timer plug-in  (0) 2014.11.18
jQuery Multiple File Upload Plugin  (0) 2014.11.18
jNotify jQuery Plug-in  (0) 2014.11.18
highlight: JavaScript text higlighting jQuery plugin  (0) 2014.11.18
: