Writing /volume1/Web/Public/dokuwiki/data/log/deprecated/2024-11-14.log failed

文書の過去の版を表示しています。


Writing /volume1/Web/Public/dokuwiki/data/log/deprecated/2024-11-14.log failed

Monitor idle state with user events

최근 ajax 관련 project를 하면서, 유저가 동작을 멈췄는지 계속 조작하고 있는지 모니터링할 필요성이 제기되었다. 이런저런 궁리를 해도 생각되로 되지 않던 차에 Google 검색에서 그럴 듯한 것이 있었다. Kaushal Sheth씨의 2007/10/17일자로 투고된 기사에 유용한 소스가 있었다. 하지만 문제는 project에서 사용하고 있던 dojo toolkit이 아니라 prototype 프레임워크로 작성되어 있었다.

dojo toolkit으로 검색해 봐도 그럴듯한 것이 없어서 결국 위의 블로그 기사를 토대로 dojo toolkit으로 포팅하기로 마음먹게 되었다. 자세한 것은 원문을 확인하기 바라고, prototypedojo toolkit의 다른점만 짚고 넘어가고자 한다.

Declaring Class

제일 먼저 눈에 띄는 차이점이 Class의 선언방법이다. prototype에서는 다음과 같은 선언방식을 사용한다.

var Employee = Class.create(); /* 주의: 클래스도 객체다! 고로 var! */
Employee.prototype = {
   initialize : function(name, dept) { /* 주의: 생성자의 이름은 "initialize" 이다. ':' 이다! */
       this.name = name || "";
       this.dept = dept || "general";
   }, /* 주의: 여기 쉼표!! */  
   toString : function() { /* 주의: ':' 이다! */
        return "name=" + this.name + ",dept=" + this.dept;
   }  /* 주의: 여기에는 쉼표가 없다!! */
}); 

반면에 dojo toolkit에서는 다음과 같이 선언한다.

dojo.declare("Employee", null, { /* 주의: 클래스 이름을 따옴표로 둘러싼다! */
    constructor : function(name, dept) {  /* 주의: 생성자 이름은 "constructor" 이다! */
       this.name = name || '';
       this.dept = dept || 'general';
   },
   toString : function() {
      return "name=" + this.name + ",dept=" + this.dept;
   }
}); 

Array utility

다음으로 Array의 elements에 접근하는 방법이 서로 다르다. prototype의 경우 다음과 같은 접근방법을 사용한다.

['one', 'two', 'three'].each(function(s) {
  alert(s);
});

dojo toolkit의 경우에는 다음과 같다. Array가 인수로 들어가는 것을 빼면 큰 차이는 없다.

dojo.each(['one', 'two', 'three'], function(e){
   alert(e);
});

Add Event Listener

다음으로 event listener의 등록방법에서 차이를 보인다. 먼저 prototype의 경우를 살펴보자. 예를 들어 다음과 같이 간단한 form 이 있다고 가정하자.

<form id="signinForm" method="post" action="/auth/signin"></form>

여기에 form을 submit할때 checkForm이라는 메소드를 등록하고 싶다. 물론 form태그에 집어넣어도 되겠지만, 좀 더 깔끔하게 처리 하고 싶다. 그럴경우에 다음과 같이 page를 로딩할 때 form object에 이벤트를 등록하는 방법이 있다.

Event.observe(window, 'load', function() {
  Event.observe('signinForm', 'submit', checkForm);
});

훨씬 깔끔해 보이지 않는가?8-o 이 코드를 dojo toolkit으로 다음과 같이 표현할 수 있다.

dojo.addOnLoad(function(){
   dojo.connect(dojo.byId('signinForm'), 'submit', 'checkForm');
});

Trigger Custom Event

마지막으로 Custom Event를 발생시키는데서 prototypedojo toolkit이 큰 차이를 보인다. prototype에는 fire(eventName[, memo]) -> Event를 이용해 custom event를 쉽게 생성할 수 있다. 예를 들면 다음과 같다.

document.observe("widget:frobbed", function(event) {
  console.log("Element with ID (" + event.target.id +
   ") frobbed widget #" + event.memo.widgetNumber + ".");
});
 
var someNode = $('foo');
someNode.fire("widget:frobbed", { widgetNumber: 19 });
 
//-> "Element with ID (foo) frobbed widget #19."

여기서 memo는 나중에 event를 통해서 접근할 수 있어서, 어떤 값을 저장하는데 상당히 편리하다.

이에 비해 dojo toolkitPublish/Subscribe라는 강력한 Event System을 가지고 있다. prototype의 fire에 해당하는 것이 dojo.publish이고, event를 listener에 연결하는 것이 dojo.subscribe이다.

어떤 의미에서는 Observer Pattern이라고 볼 수 있다. publish하는 쪽에서는 누가 subscribe를 해도 신경쓸 필요가 없다.
덕분에 event와 listener사이의 decoupling(분리) 가 가능하게 되었다. 그만큼 유연하고 강력한 event system이라고 생각한다.

사용예는 다음과 같다.

 dojo.subscribe("alerts", null, function(caption, message){ alert(caption + "\n" + message); };
 dojo.publish("alerts", [ "read this", "hello world" ]); 
//

Demo page

Here’s a little demo page to see this in action.

reference

コメント

YEEZY, 2024/06/13 01:11

https://www.yeezyslidess.us.com/ Yeezy Slides https://www.yeezyslidess.us.com/category/yeezys-350/ Yeezy 350 https://www.yeezyfoamrunner.net/ Yeezy Foam Runner https://www.yeezyslides.us.com/ Yeezy Slides https://www.yeezy-shoes.us.com/ Yeezy Shoes https://www.yeezy-shoes.us.com/category/yeezys-slides/ https://www.yeezy-supplys.us.com/ Yeezy Supply https://www.yeezy-foamrunner.com/ Yeezy Foam Runner https://www.yeezyshoess.us.com/category/yeezys-slides/ https://www.yeezyshoess.us.com/ Yeezy Shoes https://www.yeezysupplys.us.com/ Yeezy Supply https://www.yeezyslidess.com/ Yeezy Slides https://www.yeezyslidess.us.com/ Yeezy Slides https://www.yeezyfoamrunner.net/ Yeezy https://www.yeezyslides.us.com/ Yeezy Slides Website https://www.yeezy-shoes.us.com/ Yeezy https://www.yeezy-supplys.us.com/ Yeezy Shoes https://www.yeezy-foamrunner.com/ Yeezy https://www.yeezy-supplys.us.com/category/yeezys-slides/ Yeezy Slides https://www.yeezyshoess.us.com/ Yeezy Shoes For Women https://www.yeezysupplys.us.com/ Yeezy https://www.yeezyslides.us.com/category/yeezys-500/ yeezy 500 https://www.yeezyslidess.com/ Yeezy Slides 2022 https://www.yeezyoutlets.com/ Yeezy Outlet https://www.yeezyoutlets.com/category/yeezys-350/ https://www.yeezysupplywebsite.com/ Yeezy Supply Website https://www.yeezysupplywebsite.com/category/yeezys-350/ https://www.yeezystore.org/ Yeezy Store https://www.yeezyshoess.us.com/category/yeezys-350/ https://www.yeezystore.org/category/yeezys-350/ https://www.yeezysupplyshipping.com/ Yeezy Supply https://www.yeezysupplyshipping.com/category/yeezys-350/ https://www.yeezyslidesprice.com/ Yeezy Slides Price https://www.yeezysofficialwebsite.com/ Adidas Yeezy Official Website https://www.yeezysofficialwebsite.com/category/yeezys-380/ https://www.yeezy-supplys.us.com/category/yeezys-350/ https://www.yeezy-supplys.us.com/category/yeezys-380/ https://www.yeezy-shoes.us.com/category/yeezys-350/ https://www.yeezy-supplys.us.com/sitemap.xml https://www.yeezyoutlets.com/sitemap.xml https://www.yeezystore.org/sitemap.xml https://www.yeezysupplywebsite.com/sitemap.xml https://www.yeezyslidess.us.com/sitemap.xml https://www.yeezyfoamrunner.net/sitemap.xml https://www.yeezyslides.us.com/sitemap.xml https://www.yeezyslidesprice.com/sitemap.xml https://www.yeezyslidess.us.com/sitemap.xml https://www.yeezy-shoes.us.com/sitemap.xml https://www.yeezysupplyshipping.com/sitemap.xml https://www.yeezysofficialwebsite.com/sitemap.xml https://www.yeezyshoess.us.com/sitemap.xml https://www.yeezyslidess.com/sitemap-misc.xml https://www.yeezyslidess.com/sitemap-post-2022.xml https://www.yeezyslidess.com/sitemap-post-2015.xml https://www.yeezyslidess.com/sitemap-post-2014.xml https://www.yeezyslidess.com/sitemap-post-2013.xml https://www.yeezyslidess.com/sitemap-blocks-2016.xml https://www.yeezyslidess.com/sitemap-product-2024.xml https://www.yeezyslidess.com/sitemap-featured_item-2016.xml https://www.yeezyslidess.com/sitemap-category.xml https://www.yeezyslidess.com/sitemap-post_tag.xml https://www.yeezyslidess.com/sitemap-product_cat.xml https://www.yeezyslidess.com/sitemap-featured_item_category.xml https://www.yeezyslidess.com/sitemap-page.xml https://www.yeezy-supplys.us.com/sitemap-misc.xml https://www.yeezy-supplys.us.com/sitemap-post-2024.xml https://www.yeezy-supplys.us.com/sitemap-post-2022.xml https://www.yeezy-supplys.us.com/sitemap-post-2015.xml https://www.yeezy-supplys.us.com/sitemap-post-2014.xml https://www.yeezy-supplys.us.com/sitemap-post-2013.xml https://www.yeezy-supplys.us.com/sitemap-blocks-2016.xml https://www.yeezy-supplys.us.com/sitemap-product-2024.xml https://www.yeezy-supplys.us.com/sitemap-featured_item-2016.xml https://www.yeezy-supplys.us.com/sitemap-category.xml https://www.yeezy-supplys.us.com/sitemap-post_tag.xml https://www.yeezy-supplys.us.com/sitemap-product_cat.xml https://www.yeezy-supplys.us.com/sitemap-featured_item_category.xml https://www.yeezy-supplys.us.com/sitemap-page.xml https://www.yeezyshoess.us.com/sitemap-misc.xml https://www.yeezyshoess.us.com/sitemap-post-2022.xml https://www.yeezyshoess.us.com/sitemap-post-2015.xml https://www.yeezyshoess.us.com/sitemap-post-2014.xml https://www.yeezyshoess.us.com/sitemap-post-2013.xml https://www.yeezyshoess.us.com/sitemap-blocks-2016.xml https://www.yeezyshoess.us.com/sitemap-product-2024.xml https://www.yeezyshoess.us.com/sitemap-featured_item-2016.xml https://www.yeezyshoess.us.com/sitemap-category.xml https://www.yeezyshoess.us.com/sitemap-post_tag.xml https://www.yeezyshoess.us.com/sitemap-product_cat.xml https://www.yeezyshoess.us.com/sitemap-featured_item_category.xml https://www.yeezyshoess.us.com/sitemap-page.xml

コメントを入力. Wiki文法が有効です:
V U J U C
 

QR Code
QR Code study:javascript:dojo:monitor (generated for current page)