336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.
http://qooxdoo.org/

Document Information

Last modified:
2006/08/18 23:41 by wpbasti

Demo

At-a-Glance

Well, it actually does not include all of qooxdoo’s widgets in just one example. Nonetheless it is a good example for qooxdoo’s versatility.

Showcases

Complex application-like interface using multiple qooxdoo widgets.

Examples

Easily to understand examples. The basic features of each qooxdoo widget is demonstrated in a separate example. This section is probably the one you are looking for!

Tests

These tests demonstrate internal functionality of qooxdoo. Not really useful for the typical qooxdoo user, but needed for developers to test some complex layout stuff, performance related problems and more. The tests may not always be up-to-date and functioning!

Performance

These tests are used to test performance of different javascript/qooxdoo rountines and allows them to compare them with each other

Information

Last modified:
2006/08/18 23:41 by wpbasti

Account

Not logged in

Job Offers

To further improve qooxdoo we are seeking javascript developers. Read more...

Related Projects

Pustefix is a Java based Web application framework. Read more...

SourceForge.net Logo

Bad Behavior has blocked 7535 potential spam attempts in the last 7 days.

phpMyVisites

'IT' 카테고리의 다른 글

파이썬 - 정규식  (8) 2006.12.03
인터넷 속도 향상  (0) 2006.09.18
http://www.dhtmlgoodies.com/index.html  (0) 2006.09.07
HTTP로 나누는 대화  (0) 2006.09.05
HTTP 에러 코드  (0) 2006.09.05
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

A library of DHTML and AJAX scripts

Latest new scripts

Last updated scripts

'IT' 카테고리의 다른 글

인터넷 속도 향상  (0) 2006.09.18
Qooxdoo.org  (1) 2006.09.07
HTTP로 나누는 대화  (0) 2006.09.05
HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.
HTTP를 이용한 웹써버와 클라이언트의 대화
이명헌 (@피드백), 2000-12-6

리퀘스트 헤더 (Request Header)

transaction웹 브라우져가 웹 써버와 커넥션을 형성하고 문서 요청을 할 때, 어떤 과정이 진행될까요? 사용자가 링크를 클릭했을 때 웹 브라우져는 우선 요청한 페이지의 IP 주소를 찾습니다. 웹 문서 주소를 쳤을 때 원하는 페이지가 뜨는 대신 "Server does not have a DNS entry" 같은 메시지가 뜨는 경우가 IP 주소를 찾아내지 못 했을 때입니다. 일단 IP 주소에 해당하는 웹 써버를 찾았다면 웹 브라우져는 클라이언트 컴퓨터의 IP 주소를 웹 써버에 알려 주면서 웹 써버와 클라이언트 간에 TCP 커넥션을 엽니다. TCP는 "Transmission Control Protocol"의 약자로 인터넷을 전체적으로 묶어주는 네트웍 프로토콜입니다. 자세한 내용은 TCP와 네트웍 프로토콜을 참고 하세요.

웹 써버와 클라이언트(웹 브라우져) 사이에 일단 연결이 형성되면 웹 브라우져는 사용자의 리퀘스트(request)를 웹 써버에 알려 줍니다.이 리퀘스트는 일정한 형태를 갖고 있습니다. 이해를 돕기 위해 사용자가 "www.abc.co.kr/abc.html"이라는 문서에서 "www.xyz.com/xyz.html" 라는 링크를 클릭했다고 합시다. 이 링크를 클릭하는 순간 웹 브라우져는 다음과 같은 리퀘스트를 만들어 냅니다.

Get /xyz.html HTTP/1.0
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)
Accept: text/html; */*
Cookie: name = value
Referer: http://www.abc.com/abc.html
Host: www.xyz.com

첫 번째 줄은 "사용하는 프로토콜은 HTTP 1.0 이고, / 디렉토리의 xyz.html 문서를 달라"의 의미입니다. GET은 "method" 중 하나입니다. 자세한 내용은 GET vs POST를 읽어 보세요. 첫 줄 아래에 나오는 줄들을 모두 합쳐서 '리퀘스트 헤더'(request header)라고 합니다. 자세히 살펴 봅시다.

  • User-Agent: 사용자가 이용하고 있는 브라우져가 무엇인지입니다. 위의 경우, 윈도우즈 NT에서 인터넷 익스플로러 6.0을 이용해서 접속하고 있다는 것을 써버에 알려 주고 있습니다.
  • Accept: 써버로부터 받는 데이타 중 어떤 유형(type)의 데이타를 웹 브라우져가 다룰 수 있는지입니다. "text/html"은 문서 중 html 문서를 받을 수 있다는 의미이고 그 옆의 "*/*"는 특정한 유형이 아닌 모든 일반적인 형태를 다 허용한다는 의미입니다. 즉, Accept는 사용자 웹 브라우져에서 처리할 수 있는 마임타입(mime type)을 알려 줍니다.
  • Cookie: 쿠키가 무엇인지는[인터넷] 쿠키(Cookies)를 참고 하세요. Cookie 헤더는 사용자 하드 디스크에 쿠키가 있는 경우 그 쿠키의 이름과 값(name, value)을 읽어 들여서 웹 써버로 전송합니다.
  • Referer: Referer 헤더는 클릭한 링크가 담겨 있는 문서 주소를 웹 써버에 알려 줍니다. 즉, 어디로부터 이 페이지를 접속했는지를 웹 써버에게 알려 줍니다.
  • Host: 사용자가 요청한 주소의 호스트입니다. 즉, 웹 써버 주소입니다. 위의 경우 www.xyz.com입니다.

이외에도 웹 페이지가 수정된 경우 가장 최근 버전의 페이지를 전송해 달라는 요청인 If-Modified-Since와 특정 날짜가 지난 뒤에 특정 페이지나 이미지로의 접속을 차단하는 Expires 헤더가 있습니다.

리스판스 헤더 (Response Header)

apache웹 써버가 위와 같은 요청을 받으면 요청한 클라이언트에게 요청받은 내용과 함께 관련되는 정보를 담고 있는 헤더도 보냅니다. 그것을 리스판스 헤더라고 합니다. 리스판스 헤더는 상태(status) 정보를 담고 있습니다. 상태 정보는 "Found"와 "404 Not Found" 중 하나의 값을 갖습니다. 리스판스 헤더입니다.

HTTP/1.0 200 Found
Date: Mon, 10 Feb 1997 23:48:22 GMT
Server: Apache/1.1.1 HotWired/1.0
Content-type: text/html
Last-Modified: Tues, 11 Feb 2000 22:45:55 GMT

첫 줄은 상태 정보 "status"입니다. 사용자가 요청한 문서가 써버에 있으면, "Found", 못 찾았다면 "404 Not Found"입니다.

  • Date: 요청된 내용을 수행하는 시간과 날짜입니다.
  • Server: 웹 써버의 종류입니다.
  • Content-type: 보내는 문서의 마임타입입니다.
  • Last-Modified: 보내는 문서가 마지막으로 수정된 날짜입니다.

보내는 파일이 html 문서가 아니라면 Content-type 헤더에는 다른 마임타입이 담깁니다. 즉, 하나의 웹 페이지에 담겨 있는 모든 아이템들 각각에 대해서 Content-type이 무엇인지를 알려주고 전송받습니다. 이미지는 이미지별로 html은 html별로.

웹 써버 쪽에서 http 헤더를 어떻게 셋팅하는지에 관련되는 기술적 내용은 [펄] 펄을 이용한 CGI 개발을 읽어 보세요.

'IT' 카테고리의 다른 글

Qooxdoo.org  (1) 2006.09.07
http://www.dhtmlgoodies.com/index.html  (0) 2006.09.07
HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
Ajax: A New Approach to Web Applications  (0) 2006.08.22
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

HTTP 에러 코드

클라이언트가 서버에 접속하여 어떠한 요청을 하면, 서버는 세 자리 수로 된 에러 코드와 함께 응답한다. HTTP의 에러 코드는 다음과 같다.

코드 메세지 설명
1XX Informational(정보) 정보 교환.
100 Continue 클라이언트로부터 일부 요청을 받았으니 나머지 요청 정보를 계속 보내주길 바람. (HTTP 1.1에서 처음 등장)
101 Switching Protocols 서버는 클라이언트의 요청대로 Upgrade 헤더를 따라 다른 프로토콜로 바꿀 것임. (HTTP 1.1에서 처음 등장)
2XX Success(성공) 데이터 전송이 성공적으로 이루어졌거나, 이해되었거나, 수락되었음.
200 OK 에러 없이 전송 성공.
202 Accepted 서버가 클라이언트의 요청을 수락함.
203 Non-authoritavive Information 서버가 클라이언트 요구중 일부만 전송.
204 Non Content 클라이언트의 요구를 처리했으나 전송할 데이터가 없음.
205 Reset Content 새 문서 없음. 하지만 브라우저는 문서 창을 리셋해야 함. (브라우저가 CGI 폼 필드를 전부 지우도록 할 때 사용됨.) (HTTP 1.1에서 처음 등장)
206 Partial Content 클라이언트가 Range 헤더와 함께 요청의 일부분을 보냈고 서버는 이를 수행했음. (HTTP 1.1에서 처음 등장)
3XX Redirection(방향바꿈) 자료의 위치가 바뀌었음.
300 Multiple Choisces 최근에 옮겨진 데이터를 요청.
301 Moved Permanently 요구한 데이터를 변경된 URL에서 찾았음.
302 Moved Permanently 요구한 데이터가 변경된 URL에 있음을 명시. 301과 비슷하지만 새 URL은 임시 저장 장소로 해석됨.
303 See Other 요구한 데이터를 변경하지 않았기 때문에 문제가 있음.
304 Not modified 클라이언트의 캐시에 이 문서가 저장되었고 선택적인 요청에 의해 수행됨 (보통 지정된 날짜보다 더 나중의 문서만을 보여주도록 하는 If-Modified-Since 헤더의 경우).
305 Use Proxy 요청된 문서는 Location 헤더에 나열된 프록시를 통해 추출되어야 함. (HTTP 1.1에서 처음 등장)
307 Temporary Redirect 자료가 임시적으로 옮겨짐.
4XX Client Error(클라이언트 에러) 클라이언트 측의 에러. 주소를 잘못 입력하였거나 요청이 잘못 되었음.
400 Bad Request 요청 실패. 문법상 오류가 있어서 서버가 요청사항을 이해하지 못함,
401.1 Unauthorized 권한 없음 (접속실패). 서버에 로그온 하려는 요청사항이 서버에 들어있는 권한과 비교했을 때 맞지 않음.
401.2 Unauthorized 권한 없음 (서버설정으로 인한 접속 실패). 서버에 로그온 하려는 요청사항이 서버에 들어있는 권한과 비교했을 때 맞지않음.
401.3 Unauthorized 권한 없음 (자원에 대한 ACL에 기인한 권한 없음). 클라이언트가 특정 자료에 접근할 수 없음.
401.4 Unauthorized 권한 없음 (필터에 의한 권한 부여 실패). 서버에 접속하는 사용자들을 확인하기 위해 설치한 필터 프로그램이 있음.
401.5 Unauthorized 권한 없음 (ISA PI/CGI 애플리케이션에 의한 권한부여 실패). 이용하려는 서버의 주소에 ISA PI나 CGI프로그램이 설치되어 있고, 권한을 부여할 수 없음.
402 Payment Required 예약됨.
403.1 Forbidden 금지 (수행접근 금지). 수행시키지 못하도록 되어있는 디렉토리 내의 실행 파일을 수행하려고 하였음.
403.2 Forbidden 금지 (읽기 접근 금지). 접근한 디렉토리에 가용한 디폴트 페이지가 없음.
403.4 Forbidden 금지 (SSL 필요함). 접근하려는 페이지가 SSL로 보안유지 되고 있음.
403.5 Forbidden 금지 (SSL 128필요함). 페이지가 128비트의 SSL로 보안유지 되고 있음.
403.6 Forbidden 금지 (IP 주소 거부됨). 사용자가 허용되지 않은 IP로부터 접근함.
403.7 Forbidden 금지 (클라이언트 확인 필요). 클라이언트가 자료에 접근할 수 있는지 확인 요함.
403.8 Forbidden 금지 (사이트 접근 거부됨). 서버가 요청사항을 수행하고 있지 않거나, 해당 사이트에 접근하는 것이 허락되지 않음.
403.9 Forbidden 접근금지 (연결된 사용자수 과다). 서버가 BUSY 상태에 있어서 요청을 수행할 수 없음.
403.10 Forbidden 접근금지 (설정이 확실 하지 않음).
403.11 Forbidden 접근금지 (패스워드 변경됨). 잘못된 패스워드를 입력했음.
403.12 Forbidden 접근금지(Mapper 접근 금지됨). 클라이언트 인증용 맵이 해당 웹 사이트에 접근하는 것이 거부됨.
404 Not Found 문서를 찾을 수 없음. 서버가 요청한 파일이나 스크립트를 찾지 못함.
405 Method not allowed 메서드 허용안됨. 요청 내용에 명시된 메서드를 수행하기 위해 해당 자원의 이용이 허용되지 않음.
406 Not Acceptable 받아들일 수 없음.
407 Proxy Authentication Required 프록시 서버의 인증이 필요함.
408 Request timeout 요청 시간이 지남.
409 Conflict 요청을 처리하는데 문제가 있음. 보통 PUT 요청과 관계가 있다. 보통 틀린 버전의 파일을 업로드할 경우 발생함. (HTTP 1.1에서 새로 등장)
410 Gone 영구적으로 사용할 수 없음.
411 Length Required 클라이언트가 헤더에 Content-Length를 포함하지 않으면 서버가 처리할 수 없음.(HTTP 1.1에서 새로 등장)
412 Precondition Failed 선결조건 실패. 헤더에 하나 이상의 선결조건을 서버에서 충족시킬 수 없음.
413 Request entity too large 요청된 문서가 현재 서버가 다룰 수 있는 크기보다 큼. (HTTP 1.1에서 새로 등장)
414 Request-URI too long 요청한 URI가 너무 김.
415 Unsupported media type 요청이 알려지지 않은 형태임. (HTTP 1.1에서 새로 등장)
5XX Server Error(서버 에러) 서버 측의 에러로 올바른 요청을 처리할 수 없음.
500 Internal Server Error 서버 내부 오류.
501 Not Implemented 필요한 기능이 서버에 설치되지 않았음.
502 Bad gateway 게이트웨이 상태 나쁨.
503 Service Unavailable 외부 서비스가 죽었거나 현재 멈춘 상태 또는 이용할 수 없는 서비스.
504 Gateway timeout 프록시나 게이트웨이의 역할을 하는 서버에서 볼 수 있음. 초기 서버가 원격 서버로부터 응답을 받을 수 없음. (HTTP 1.1에서 새로 등장)
505 HTTP Version Not Supported 해당 HTTP 버젼을 지원하지 않음.

'IT' 카테고리의 다른 글

http://www.dhtmlgoodies.com/index.html  (0) 2006.09.07
HTTP로 나누는 대화  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
Ajax: A New Approach to Web Applications  (0) 2006.08.22
script.aculous wiki 사이트  (0) 2006.08.14
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

I decided to make a list of the top libraries that I have come across or that I personally use. Libraries can be a web developers best friend. They are great resources to learn from and can save hours and hours of time. These libraries include JavaScript, Ajax, Colors, PHP, and CSS. These should be in any web developers bookmarks, so go ahead and look through these libraries and bookmark your favorite ones. The list is in no particular order.

1) Moo.fx - A superlightweight, ultratiny, megasmall javascript effects library, written with prototype.js. It’s easy to use, fast, cross-browser, standards compliant, provides controls to modify Height, Width, and Opacity with builtin checks that won’t let a user break the effect with multiple crazy clicks. It’s also optimized to make you write the lesser code possible.

2) Rico - An open source JavaScript library for creating rich internet applications. Provides full Ajax support, drag and drop management, and a cinematic effects library.

3) Swat - Developed by silverorange, Swat is an open source web application toolkit built with PHP.

4) ColorCombos - Who would’ve thought a color library would end up mixed in with a bunch of JavaScript and PHP libraries? Well they do have a pretty sweet little color library for finding color combinations, all you do is select the color and they show you some nice combos that work with that color.

5) script.aculo.us - Provides you with easy-to-use, compatible and, ultimately, totally cool JavaScript libraries to make your web sites and web applications fly, Web 2.0 style. I’m sure I’m not alone when I say this library is my favorite.

6) Mochikit - A kick-ass lightweight JavaScript library that will help you get shit done fast.

7) Dynamic Drive CSS Library - Here you’ll find original, practical CSS codes and examples such as CSS menus to give your site a visual boast.

8) PEAR - A framework and distribution system for reusable PHP components. PEAR provides the above mentioned PHP components in the form of so called “Packages”.

9) DHTML Goodies - A good sized library of DHTML and AJAX scripts.

10) dojo - Open source JavaScript toolkit that makes professional web development better, easier, and faster.

Honorable Mentions

11) Cross Browser | Toys - Huge JavaScript library.

12) Yahoo UI Library - The Yahoo! User Interface (YUI) Library is a set of utilities and controls, written in JavaScript, for building richly interactive web applications using techniques such as DOM scripting, DHTML and AJAX. The YUI Library also includes several core CSS resources.

Big thanks to all of those who have help in anyway to put one of these libraries together.

I hope you find this list helpful. Keep in mind there’s hundred of libraries available online, I don’t know all of them and I’m sure I missed a few good ones, feel free to add your favorites in the comments below.

'IT' 카테고리의 다른 글

HTTP로 나누는 대화  (0) 2006.09.05
HTTP 에러 코드  (0) 2006.09.05
Ajax: A New Approach to Web Applications  (0) 2006.08.22
script.aculous wiki 사이트  (0) 2006.08.14
prototype.js 를 위한 개발자 노트  (0) 2006.08.14
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.
AJAX 라는 용어가 처음 사용된 곳..

제시 제임스 가렛이 쓴 에세이...



Ajax: A New Approach to Web

Applications

February 18, 2005

If anything about current interaction design can be called “glamorous,” it’s creating Web applications. After all, when was the last time you heard someone rave about the interaction design of a product that wasn’t on the Web? (Okay, besides the iPod.) All the cool, innovative new projects are online.

Despite this, Web interaction designers can’t help but feel a little envious of our colleagues who create desktop software. Desktop applications have a richness and responsiveness that has seemed out of reach on the Web. The same simplicity that enabled the Web’s rapid proliferation also creates a gap between the experiences we can provide and the experiences users can get from a desktop application.

That gap is closing. Take a look at Google Suggest. Watch the way the suggested terms update as you type, almost instantly. Now look at Google Maps. Zoom in. Use your cursor to grab the map and scroll around a bit. Again, everything happens almost instantly, with no waiting for pages to reload.

Google Suggest and Google Maps are two examples of a new approach to web applications that we at Adaptive Path have been calling Ajax. The name is shorthand for Asynchronous JavaScript + XML, and it represents a fundamental shift in what’s possible on the Web.

Defining Ajax

Ajax isn’t a technology. It’s really several technologies, each flourishing in its own right, coming together in powerful new ways. Ajax incorporates:

The classic web application model works like this: Most user actions in the interface trigger an HTTP request back to a web server. The server does some processing — retrieving data, crunching numbers, talking to various legacy systems — and then returns an HTML page to the client. It’s a model adapted from the Web’s original use as a hypertext medium, but as fans of The Elements of User Experience know, what makes the Web good for hypertext doesn’t necessarily make it good for software applications.

Ajax Overview 1

Figure 1: The traditional model for web applications (left) compared to the Ajax model (right).

This approach makes a lot of technical sense, but it doesn’t make for a great user experience. While the server is doing its thing, what’s the user doing? That’s right, waiting. And at every step in a task, the user waits some more.

Obviously, if we were designing the Web from scratch for applications, we wouldn’t make users wait around. Once an interface is loaded, why should the user interaction come to a halt every time the application needs something from the server? In fact, why should the user see the application go to the server at all?

How Ajax is Different

An Ajax application eliminates the start-stop-start-stop nature of interaction on the Web by introducing an intermediary — an Ajax engine — between the user and the server. It seems like adding a layer to the application would make it less responsive, but the opposite is true.

Instead of loading a webpage, at the start of the session, the browser loads an Ajax engine — written in JavaScript and usually tucked away in a hidden frame. This engine is responsible for both rendering the interface the user sees and communicating with the server on the user’s behalf. The Ajax engine allows the user’s interaction with the application to happen asynchronously — independent of communication with the server. So the user is never staring at a blank browser window and an hourglass icon, waiting around for the server to do something.

Ajax Overview 2

Figure 2: The synchronous interaction pattern of a traditional web application (top) compared with the asynchronous pattern of an Ajax application (bottom).

Every user action that normally would generate an HTTP request takes the form of a JavaScript call to the Ajax engine instead. Any response to a user action that doesn’t require a trip back to the server — such as simple data validation, editing data in memory, and even some navigation — the engine handles on its own. If the engine needs something from the server in order to respond — if it’s submitting data for processing, loading additional interface code, or retrieving new data — the engine makes those requests asynchronously, usually using XML, without stalling a user’s interaction with the application.

Who’s Using Ajax

Google is making a huge investment in developing the Ajax approach. All of the major products Google has introduced over the last year — Orkut, Gmail, the latest beta version of Google Groups, Google Suggest, and Google Maps — are Ajax applications. (For more on the technical nuts and bolts of these Ajax implementations, check out these excellent analyses of Gmail, Google Suggest, and Google Maps.) Others are following suit: many of the features that people love in Flickr depend on Ajax, and Amazon’s A9.com search engine applies similar techniques.

These projects demonstrate that Ajax is not only technically sound, but also practical for real-world applications. This isn’t another technology that only works in a laboratory. And Ajax applications can be any size, from the very simple, single-function Google Suggest to the very complex and sophisticated Google Maps.

At Adaptive Path, we’ve been doing our own work with Ajax over the last several months, and we’re realizing we’ve only scratched the surface of the rich interaction and responsiveness that Ajax applications can provide. Ajax is an important development for Web applications, and its importance is only going to grow. And because there are so many developers out there who already know how to use these technologies, we expect to see many more organizations following Google’s lead in reaping the competitive advantage Ajax provides.

Moving Forward

The biggest challenges in creating Ajax applications are not technical. The core Ajax technologies are mature, stable, and well understood. Instead, the challenges are for the designers of these applications: to forget what we think we know about the limitations of the Web, and begin to imagine a wider, richer range of possibilities.

It’s going to be fun.


Ajax Q&A

March 13, 2005: Since we first published Jesse’s essay, we’ve received an enormous amount of correspondence from readers with questions about Ajax. In this Q&A, Jesse responds to some of the most common queries.

Q. Did Adaptive Path invent Ajax? Did Google? Did Adaptive Path help build Google’s Ajax applications?

A. Neither Adaptive Path nor Google invented Ajax. Google’s recent products are simply the highest-profile examples of Ajax applications. Adaptive Path was not involved in the development of Google’s Ajax applications, but we have been doing Ajax work for some of our other clients.

Q. Is Adaptive Path selling Ajax components or trademarking the name? Where can I download it?

A. Ajax isn’t something you can download. It’s an approach — a way of thinking about the architecture of web applications using certain technologies. Neither the Ajax name nor the approach are proprietary to Adaptive Path.

Q. Is Ajax just another name for XMLHttpRequest?

A. No. XMLHttpRequest is only part of the Ajax equation. XMLHttpRequest is the technical component that makes the asynchronous server communication possible; Ajax is our name for the overall approach described in the article, which relies not only on XMLHttpRequest, but on CSS, DOM, and other technologies.

Q. Why did you feel the need to give this a name?

A. I needed something shorter than “Asynchronous JavaScript+CSS+DOM+XMLHttpRequest” to use when discussing this approach with clients.

Q. Techniques for asynchronous server communication have been around for years. What makes Ajax a “new” approach?

A. What’s new is the prominent use of these techniques in real-world applications to change the fundamental interaction model of the Web. Ajax is taking hold now because these technologies and the industry’s understanding of how to deploy them most effectively have taken time to develop.

Q. Is Ajax a technology platform or is it an architectural style?

A. It’s both. Ajax is a set of technologies being used together in a particular way.

Q. What kinds of applications is Ajax best suited for?

A. We don’t know yet. Because this is a relatively new approach, our understanding of where Ajax can best be applied is still in its infancy. Sometimes the traditional web application model is the most appropriate solution to a problem.

Q. Does this mean Adaptive Path is anti-Flash?

A. Not at all. Macromedia is an Adaptive Path client, and we’ve long been supporters of Flash technology. As Ajax matures, we expect that sometimes Ajax will be the better solution to a particular problem, and sometimes Flash will be the better solution. We’re also interested in exploring ways the technologies can be mixed (as in the case of Flickr, which uses both).

Q. Does Ajax have significant accessibility or browser compatibility limitations? Do Ajax applications break the back button? Is Ajax compatible with REST? Are there security considerations with Ajax development? Can Ajax applications be made to work for users who have JavaScript turned off?

A. The answer to all of these questions is “maybe”. Many developers are already working on ways to address these concerns. We think there’s more work to be done to determine all the limitations of Ajax, and we expect the Ajax development community to uncover more issues like these along the way.

Q. Some of the Google examples you cite don’t use XML at all. Do I have to use XML and/or XSLT in an Ajax application?

A. No. XML is the most fully-developed means of getting data in and out of an Ajax client, but there’s no reason you couldn’t accomplish the same effects using a technology like JavaScript Object Notation or any similar means of structuring data for interchange.

Q. Are Ajax applications easier to develop than traditional web applications?

A. Not necessarily. Ajax applications inevitably involve running complex JavaScript code on the client. Making that complex code efficient and bug-free is not a task to be taken lightly, and better development tools and frameworks will be needed to help us meet that challenge.

Q. Do Ajax applications always deliver a better experience than traditional web applications?

A. Not necessarily. Ajax gives interaction designers more flexibility. However, the more power we have, the more caution we must use in exercising it. We must be careful to use Ajax to enhance the user experience of our applications, not degrade it.

Jesse James Garrett is the Director of User Experience Strategy and a founder of Adaptive Path. He is the author of the widely-referenced book The Elements of User Experience. Jesse’s other essays include The Nine Pillars of Successful Web Teams and Six Design Lessons From the Apple Store.

To get essays like this one delivered directly to your inbox, subscribe to our email newsletter. For more, check out our blog.


[Photo: Jesse James Garrett]

Jesse James Garrett is the Director of User Experience Strategy and a founder of Adaptive Path. He is the author of the widely-referenced book The Elements of User Experience. Jesse’s other essays include The Nine Pillars of Successful Web Teams and Six Design Lessons From the Apple Store.

To get essays like this one delivered directly to your inbox, subscribe to our email newsletter. For more, check out our blog.

Printer-friendly version

Syndicate this site

Powered by
Movable Type 2.661

Creative Commons License

This work is licensed under a Creative Commons License.

'IT' 카테고리의 다른 글

HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
script.aculous wiki 사이트  (0) 2006.08.14
prototype.js 를 위한 개발자 노트  (0) 2006.08.14
Yahoo! Ajax UI 가이드 라인 무료 공개  (1) 2006.08.11
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

scriptaculous wiki


Discuss (6 comments)
Print
E-mail



The script.aculo.us Wiki is a place for documentation, hints, tips and tricks for the script.aculo.us libraries. Everyone can contribute (see Contribute)!

New to script.aculo.us? Start here.


The basics

Usage
Demos
FAQ
The Wishlist
Bug Reports
Development
Official MailingList (as forum), IRCChannel

Want to be an author on the wiki? Hop over to the authors page and invite yourself (see the Invitations tab).

You can discuss wiki pages right here in the wiki with the “Discuss page name” link in the box on the right, plus there’s an unofficial User forum.

Need paid development services? See Available For Hire.

Versions, Development, Praise, License
Documentation Wishes, Java Script Documentation


Prototype Java Script framework

script.aculo.us's prototype library documentation
official prototype homepage


script.aculo.us effects

Visual Effects: A visual effects framework for (X)HTML/CSS which includes a series of extensible Core Effects, and prepackaged Combination Effects.

User-submitted add-on effects go into the Effects Treasure Chest.


script.aculo.us controls

Drag And Drop: Draggables, Droppables, Sortables, Slider
Autocompletion: autocompleting text fields, AJAX- or Client-powered
In Place Editing: AJAX-powered text fields generated on-demand


script.aculo.us utils

Builder: A helper to build DOM fragments in Java Script


script.aculo.us JavaScript testing

Unit Testing: Java Script unit tests, with DOM event simulation and assertions
Functional Testing: Ghost Train, a record/replay framework (alpha)


Integration with development frameworks

Ruby On Rails, Perl, Nitro, PHP, Java, Plone, DotNet, Symfony, Seaside


Extensions, Demos and Links

Extensions, Real World Usage

'IT' 카테고리의 다른 글

HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
Ajax: A New Approach to Web Applications  (0) 2006.08.22
prototype.js 를 위한 개발자 노트  (0) 2006.08.14
Yahoo! Ajax UI 가이드 라인 무료 공개  (1) 2006.08.11
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

prototype.js 를 위한 개발자 노트

1.4.0 버전을 다룸

Sergio PereiraSergio Pereira에 의해 작성됨
최근 업데이트: 2006년 4월 13일

Table of Contents

Prototype은 무엇인가.?

prototype.jsSam Stephenson에 의해 작성된 자바스크립트 라이브러리이다. 이 놀랍도록 멋진 생각과 표준에 의해 잘 작성된 코드의 일부는 웹2.0의 특성을 나타내는 풍부하고 상호작용하는 웹페이지와 많은 연관을 가진다.

만약 당신이 최근 이 라이브러리를 사용하기 시작했다면, 당신은 아마도 이 문서가 가장 좋은 지시사항중에 하나는 아니라는것을 알아차렸을것이다. 나 이전에 다른 많은 개발자들처럼, 나는 소스코드와 이것을 사용한 경험에서 prototype.js에 대한 지식을 가지게 되었다. 나는 모든 이가 배우고 공유하는 동안 좀더 많은 정보를 얻게 되는게 가장 좋은 것이라고 생각한다.

나는 objects, classes, functions, 그리고 이 라이브러리에 의해 제공되는 확장을 위한 비공식적인 참조문서 또한 제공한다.

당신이 예제와 참조문서를 읽었을때, Ruby프로그래밍 언어에 친숙한 개발자는 Ruby의 내장 클래스와 이 라이브러리에 의해 구현된 많은 확장 사이의 의도적인 유사성을 알아차리게 될것이다.

toc

관련글

고급 자바스크립트 가이드문서.

toc

유틸리티 함수들(utility functions)

라이브러리는 미리 정의된 많은 수의 객체와 유틸리티 함수를 가진다. 이 알기쉬운 함수들의 목적은 반복적인 타이핑과 어구를 많이 줄이는데 있다.

toc

$() 함수 사용하기

$()함수는 가장 많이 사용되는 DOM의 document.getElementById()함수에 대한 편리한 단축키이다. DOM함수처럼, 이것은 인자로 던져진 id를 가진 요소를 하나 반환한다.

하지만 DOM함수와는 달리, 이것은 여러개의 id를 사용할수 있고 $()는 요청된 요소를 가진 Array객체를 반환할것이다. 예제는 아래와 같다.

<HTML><HEAD><TITLE> Test Page </TITLE><script src="prototype-1.4.0.js"></script><script>	function test1()	{		var d = $('myDiv');		alert(d.innerHTML);	}	function test2()	{		var divs = $('myDiv','myOtherDiv');		for(i=0; i<divs.length; i++)		{			alert(divs[i].innerHTML);		}	}</script></HEAD><BODY>	<div id="myDiv">		<p>This is a paragraph</p>	</div>	<div id="myOtherDiv">		<p>This is another paragraph</p>	</div>	<input type="button" value=Test1 onclick="test1();"><br> 	<input type="button" value=Test2 onclick="test2();"><br> </BODY></HTML>

이 함수의 다른 좋은 점은 이것은 인자형태를 가질수 있는 다른 함수를 생성할때 매우 유용하도록 만들어주는 id문자열이나 요소객체 자체를 던질수 있다는 것이다.

toc

$F() 함수 사용하기

$F() 함수는 다른 단축키이다. 이것은 text박스나 드랍다운 list와 같은 어떤 필드의 입력 컨트롤의 값을 반환한다. 이 함수는 요소 id나 요소객체 자체를 인자로 가질수 있다.

<script>	function test3()	{		alert(  $F('userName')  );	}</script><input type="text" id="userName" value="Joe Doe"><br> <input type="button" value=Test3 onclick="test3();"><br> 			

toc

$A() 함수 사용하기

$A() 함수는 이것을 받아들이는 하나의 인자를 Array객체로 변환한다.

Array 클래스를 위한 확장과 조합된 이 함수는 이것을 더욱 쉽게 만든다. 예를 들면, 작성한 함수는 인자의 수를 유연하게 받아들인다.

<script>	function showOptions(){		var someNodeList = $('lstEmployees').getElementsByTagName('option');		var nodes = $A(someNodeList);		nodes.each(function(node){				alert(node.nodeName + ': ' + node.innerHTML);			});	}</script><select id="lstEmployees" size="10" >	<option value="5">Buchanan, Steven</option>	<option value="8">Callahan, Laura</option>	<option value="1">Davolio, Nancy</option></select><input type="button" value="Show the options" onclick="showOptions();" > 			

toc

$H() 함수 사용하기

$H() 함수는 결합된 배열을 열거할수 있는 Hash객체로 변환한다.

<script>	function testHash()	{		//let's create the object		var a = {			first: 10,			second: 20,			third: 30			};		//now transform it into a hash		var h = $H(a);		alert(h.toQueryString()); //displays: first=10&second=20&third=30	}</script>			

toc

$R() 함수 사용하기

$R() 함수는 new ObjectRange(lowerBound, upperBound, excludeBounds)를 작성하기 위한 짧은 형태이다.

이 클래스의 완전한 설명을 보기 위해 ObjectRange 클래스 문서를 보라. each 메소드를 통해 반복(iterators)의 사용법을 보여주는 간단한 예제를 보자. 더 많은 메소드는 Enumerable 클래스 문서에서 볼수 있을것이다.

<script>	function demoDollar_R(){		var range = $R(10, 20, false);		range.each(function(value, index){			alert(value);		});	}</script><input type="button" value="Sample Count" onclick="demoDollar_R();" > 			

toc

Try.these() 함수 사용하기

이것은 인자처럼 많은 수의 함수를 가지고 그것들을 순서대로 차례차례 호출하도록 해준다. 이것은 함수중에 하나씩 수행하고 성공적인 함수호출의 결과를 반환할때까지 순차적으로 수행된다.

예제는 아래와 같다. xmlNode.text는 몇몇 브라우저에서 작동하고 xmlNode.textContent는 다른 브라우저에서 작동한다. Try.these()함수를 사용하면 당신은 작동하는 것중 하나를 반환할수 있다.

<script>function getXmlNodeValue(xmlNode){	return Try.these(		function() {return xmlNode.text;},		function() {return xmlNode.textContent;}		);}</script>			

toc

Ajax 객체

위에서 언급된 유틸리티 함수들은 좋다. 하지만 다시 보자. 그것들은 대부분 고급(advanced) 형태는 아니다. 당신은 스스로 이것들을 만들수 있고 당신 자신만의 스크립트에 유사한 함수를 이미 가지고 있을수도 있다. 하지만 이러한 함수들은 단지 일부분에 해당되는 팁일뿐이다.

나는 prototype.js에 대한 당신의 관심이 대부분의 AJAX기능을 다룰수 있다는 것이라고 확신한다. 그래서 당신이 AJAX로직을 수행할 필요가 있을때 좀더 쉽게 사용하도록 도와주는 라이브러리를 사용하는 방법을 살펴보자.

AJAX객체는 AJAX함수를 작성할 때 포함되는 트릭성격의 코드를 포장하고 단순화하기 위한 라이브러리에 의해 생성된 미리-정의된 객체이다. 이 객체는 캡슐화된 AJAX로직을 제공하는 많은 수의 클래스를 포함한다. 그 클래스중에 몇개를 살펴보자.

toc

Ajax.Request 클래스 사용하기

만약 당신이 어떠한 헬퍼(helper) 라이브러리도 사용하지 않는다면, 당신은 XMLHttpRequest객체를 생성하기 위한 많은 코드를 작성할 것이고 단계를 비동기적으로 수행할것이다. 그리고나서 응답을 뽑아내고 이것을 처리한다. 그리고나서는 한가지 이상의 브라우저를 지원하지 않는다면 스스로 행운이라고 생각할 것이다.

AJAX기능을 지원하기 위해, 라이브러리는 Ajax.Request클래스를 정의한다.

당신이 다음처럼 XML응답을 반환하는 http://yoursever/app/get_sales?empID=1234&year=1998 url을 통해 서버와 통신할수 있는 애플리케이션을 가지고 있다고 해보자.

<?xml version="1.0" encoding="utf-8" ?> <ajax-response>	<response type="object" id="productDetails">		<monthly-sales>			<employee-sales>				<employee-id>1234</employee-id> 				<year-month>1998-01</year-month> 				<sales>$8,115.36</sales> 			</employee-sales>			<employee-sales>				<employee-id>1234</employee-id> 				<year-month>1998-02</year-month> 				<sales>$11,147.51</sales> 			</employee-sales>		</monthly-sales>	</response></ajax-response>						

XML을 가져오기 위해 서버와 통신하는 것은 Ajax.Request객체를 사용하면 매우 간단하다. 아래의 샘플은 이것을 수행하는 방법을 보여준다.

<script>	function searchSales()	{		var empID = $F('lstEmployees');		var y = $F('lstYears');		var url = 'http://yourserver/app/get_sales';		var pars = 'empID=' + empID + '&year=' + y;		
var myAjax = new Ajax.Request( url, { method: 'get', parameters: pars, onComplete: showResponse });
} function showResponse(originalRequest) { //put returned XML in the textarea $('result').value = originalRequest.responseText; }</script><select id="lstEmployees" size="10" onchange="searchSales()"> <option value="5">Buchanan, Steven</option> <option value="8">Callahan, Laura</option> <option value="1">Davolio, Nancy</option></select><select id="lstYears" size="3" onchange="searchSales()"> <option selected="selected" value="1996">1996</option> <option value="1997">1997</option> <option value="1998">1998</option></select><br><textarea id=result cols=60 rows=10 ></textarea>

Ajax.Request객체의 생성자의 두번째 파라미터를 알아보겠는가.? {method: 'get', parameters: pars, onComplete: showResponse} 파라미터는 문자적 표기법으로 익명 객체를 나타낸다. 이것이 의미하는 것은 'get' 문자열을 포함하는 명명된 메소드(method)의 프라퍼티, HTTP요청 문자열을 포함하는 명명된 파라미터(parameter)의 프라퍼티, 그리고 함수 showResponse를 포함하는 onComplete 프라퍼티/메소드를 가지는 객체를 전달한다는 것이다.

당신이 AJAX를 비동기적으로(asynchronous) 서버에 호출할지를 결정하고 truefalse값으로 셋팅할수 있는 asynchronous(디폴트 값은 true이다.)와 같은 이 객체내 정의하고 활성화시킬수 있는 다른 프라퍼티가 몇개 있다.

이 파라미터는 AJAX호출을 위한 옵션을 정의한다. 샘플에서, 우리는 HTTP GET명령을 통해 첫번째 인자에서 url을 호출한다. 변수 pars내 포함된 조회문자열(querystring)을 전달하고 Ajax.Request객체는 응답을 받아들이는 작업을 마칠때 showResponse함수를 호출할 것이다.

당신이 아는것처럼, XMLHttpRequest는 HTTP호출을 하는 동안 진행과정을 보고한다. 이 진행과정은 4가지의 단계(Loading, Loaded, Interactive, 또는 Complete)를 알릴수 있다. 당신은 이러한 단계중에서 Ajax.Request객체 호출을 사용자정의 함수로 만들수 있다. Complete는 가장 공통적인 단계이다. 함수를 객체에게 알리기 위해, 우리 예제의 onComplete처럼 요청옵션내 onXXXXX로 명명된 프라퍼티/메소드를 간단히 제공하라. 당신이 전달하는 이 함수는 XMLHttpRequest객체 자체가 될 하나의 인자를 가진 객체에 의해 호출될것이다. 당신은 반환 데이터를 얻기 위해 이 객체를 사용할수 있고 아마도 호출의 HTTP결과 코드를 포함할 상태(status) 프라퍼티를 체크할것이다.

두개의 다른 흥미로운 옵션은 결과를 처리하기 위해 사용될수 있다. 우리는 AJAX호출이 에러없이 수행될때 호출될 함수처럼 onSuccess옵션을 명시할수 있다. onFailure옵션은 서버에러가 발생할때 호출될 함수가 될수 있다. onXXXXX의 선택적인 함수처럼, 이 두가지는 AJAX호출이 옮기는 XMLHttpRequest객체를 전달하도록 호출될수 있을것이다.

1.4.0 버전에서, 이벤트 콜랙 핸들링의 새로운 형태가 소개되었다. 만약 당신이 AJAX호출이 발생하는데도 불구하고 특정 이벤트를 위해 수행되어야 하는 코드를 가지고 있다면, 당신은 새로운 Ajax.Responders 객체를 사용할수 있다.

당신이 AJAX호출이 진행중이라는 시각적 표시를 보여주길 원한다고 해보자. 당신은 두개의 전역 이벤트 핸들러를 사용할수 있다. 하나는 첫번째 호출이 시작되었을때 아이콘을 보여주는것이고 다른 하나는 적어도 하나가 끝났을때 아이콘을 숨기는 것이다. 아래의 예제를 보자.

<script>	var myGlobalHandlers = {		onCreate: function(){			Element.show('systemWorking');		},		onComplete: function() {			if(Ajax.activeRequestCount == 0){				Element.hide('systemWorking');			}		}	};	Ajax.Responders.register(myGlobalHandlers);</script><div id='systemWorking'><img src='spinner.gif'>Loading...</div>	

우리의 샘플은 흥미로운 방법으로 XML응답을 처리하지는 않았다. 우리는 textarea내 XML을 집어넣었다. 응답의 전형적인 사용법은 XML내부에서 바라는 정보를 찾고자 할것이고 몇몇 페이지 요소나 페이지내 HTML을 만드는 몇가지의 XSLT변형을 업데이트할것이다.

좀더 완전한 설명을 보기 위해서, Ajax.Request 참조options 참조를 보라..

toc

Ajax.Updater 클래스 사용하기

만약 당신이 HTML로 이미 포맷팅된 정보를 반환할수 있는 서버 종료점(endpoint)을 가진다면, 라이브러리는 당신이 Ajax.Updater클래스를 사용하는것을 좀더 쉽게 만들어준다. 이것으로 당신은 어느 요소가 AJAX호출로부터 반환된 HTML을 채우는지 알리게 된다. 예제는 내가 글로 표현하는 것보다 당신을 좀더 쉽게 이해하도록 도와줄것이다.

<script>	function getHTML()	{		var url = 'http://yourserver/app/getSomeHTML';		var pars = 'someParameter=ABC';		
var myAjax = new Ajax.Updater( 'placeholder', url, { method: 'get', parameters: pars });
}</script><input type=button value=GetHtml onclick="getHTML()"><div id="placeholder"></div>

당신이 보는것처럼, 코드는 onComplete함수와 생성자에 전달된 요소 id를 제외하고 이전예제에 비해서 매우 간단하다. 클라이언트에서 서버 에러들을 다루는 것이 어떻게 가능한지 보기 위해 코드를 조금 변경해 보자.

우리는 호출을 위해 더 많은 옵션을 추가하고 에러 상황을 뽑아내기 위해 함수를 명시한다. 이것은 onFailure옵션을 사용하여 수행한다. 우리는 성공적인 작동의 경우에만 활성화될 묶음자(placeholder)를 명시할것이다. 이것을 달성하기 위해, 우리는 간단한 요소 id에서 두개의 프라퍼티(success-모든것이 정상적일때 사용되는, failure-어떤것이 실패일때 사용되는)를 가지는 객체로 첫번째 파라미터를 변경할 것이다. 우리는 예제에서 failure 프라퍼티를 사용하지 않을것이고, onFailure옵션에서 reportError함수를 사용할것이다.

<script>	function getHTML()	{		var url = 'http://yourserver/app/getSomeHTML';		var pars = 'someParameter=ABC';		
var myAjax = new Ajax.Updater( {success: 'placeholder'}, url, { method: 'get', parameters: pars, onFailure: reportError });
} function reportError(request) { alert('Sorry. There was an error.'); }</script><input type=button value=GetHtml onclick="getHTML()"><div id="placeholder"></div>

만약 당신의 서버 로직이 HTML마크업 대신에 자바스크립트 코드를 반환한다면, Ajax.Updater객체는 자바스크립트 코드가 될수 있다. 자바스크립트로 응답을 처리하기 위한 객체를 얻기 위해, 당신은 객체 생성자의 마지막 인자로 프라퍼티들의 목록에 evalScripts: true;를 간단히 추가한다. 하지만 여기엔 문제가 있다. 이러한 스크립트 블럭은 페이지의 스크립트에 추가되지 않을것이다. 옵션이름인 evalScripts이 제시하는것처럼, 스크립트는 평가될것이다. 차이점이 무엇일까.? 요청된 URL이 반환하는 것이 무엇인지 추측해보자.

<script language="javascript" type="text/javascript">	function sayHi(){		alert('Hi');	}</script><input type=button value="Click Me" onclick="sayHi()">			

이 경우 당신이 이전에 이것을 시도했다면 이것이 작동하지 않는것을 알고 있을것이다. 이유는 스크립트 블럭은 평가될것이고 평가된 스크립트는 sayHi 라는 이름의 함수를 생성하지 않을것이다. 이것은 아무것도 하지 않을것이다. 이 함수를 생성하기 위해, 우리는 함수를 생성하기 위해 변경할 필요가 있다. 아래를 보라.

<script language="javascript" type="text/javascript">	
sayHi = function(){ alert('Hi'); };
</script><input type=button value="Click Me" onclick="sayHi()">

이전 예제에서, 우리는 변수를 선언하기 위해 var 키워드를 사용하지 않았다. 그렇게 하는 것은 스크립트 블럭에 지역화될 함수 객체를 생성할것이다. var 키워드 없이 함수 객체는 window범위에서 작동한다.

좀더 상세한 complete설명을 위해서는, Ajax.Request 참조문서Ajax.options 참조문서를 보라.

toc

열거(Enumerating)...

우리는 루프(loop)에 친숙하다. 당신이 알다시피, 배열 자체를 생성하고 같은 종류의 요소로 채운다. 루프 제어구조(이를 테면, foreach, while, repeat 등등)을 생성하고 숫자로 된 인덱스를 통해 순차적으로 각각의 요소에 접근하고 그 요소로 작업을 수행한다.

당신이 이것에 대해 생각할때, 언제나 당신은 코드에 배열을 가지고 루프내 배열을 사용할것이라는것을 의미한다. 이러한 반복을 다루기 위해 좀더 많은 기능을 가진 배열 객체가 있다면 좋지 않겠는가.? 그렇다. 많은 프로그래밍 언어는 배열이나 유사한 구조(collection과 list와 같은)에서 이러한 기능을 제공한다.

prototype.js는 우리에게 반복가능한 데이터를 다룰때 사용하도록 구현된 Enumerable 객체를 제공한다. prototype.js 라이브러리는 더 나아가 Enumerable의 모든 메소드로 Array 클래스를 확장한다

toc

루프, 루비-스타일

표준 자바스크립트에서, 당신이 배열의 요소를 순차적으로 표시하길 원한다면, 당신은 다음처럼 작성할수 있다.

<script>	function showList(){		var simpsons = ['Homer', 'Marge', 'Lisa', 'Bart', 'Meg'];
for(i=0;i<simpsons.length;i++){ alert(simpsons[i]); }
}</script><input type="button" value="Show List" onclick="showList();" >

prototype.js를 사용하면, 다음과 같이 다시 작성할수 있다.

	function showList(){		var simpsons = ['Homer', 'Marge', 'Lisa', 'Bart', 'Meg'];
simpsons.each( function(familyMember){ alert(familyMember); });
}

당신은 특이한 문법으로 별로 좋지않다고 생각할지도 모른다. 위 예제에서, 엉망으로 만드는 것은 아무것도 없다.

each 메소드에 대한 인자처럼 전달되는 이 함수는 보았는가.? iterator 함수처럼 이것을 참조해보자.

toc

스테로이드(steroids)에서 당신의 배열

위에서 언급된것처럼, 이것은 같은 프라퍼티와 메소드를 가지는 배열내 모든 요소를 위해 공통이다. 우리의 새로운 배열을 가지고 iterator함수의 장점을 가질수 있는 방법을 보자.

문법에 따르는 요소를 찾아라.

<script>	function findEmployeeById(emp_id){		var listBox = $('lstEmployees')		var options = listBox.getElementsByTagName('option');		options = $A(options);		var opt = options.find( function(employee){			return (employee.value == emp_id);		});		alert(opt.innerHTML); //displays the employee name	}</script><select id="lstEmployees" size="10" >	<option value="5">Buchanan, Steven</option>	<option value="8">Callahan, Laura</option>	<option value="1">Davolio, Nancy</option></select><input type="button" value="Find Laura" onclick="findEmployeeById(8);" > 			

배열에서 항목을 걸러내는 방법을 보자. 그리고나서 각각의 요소로부터 맴버를 가져온다.

<script>	function showLocalLinks(paragraph){		paragraph = $(paragraph);		var links = $A(paragraph.getElementsByTagName('a'));		//find links that do not start with 'http'		var localLinks = links.findAll( function(link){			var start = link.href.substring(0,4);			return start !='http';		});		//now the link texts		var texts = localLinks.pluck('innerHTML');		//get them in a single string		var result = texts.inspect();		alert(result);	}</script><p id="someText">	This <a href="http://othersite.com/page.html">text</a> has 	a <a href="#localAnchor">lot</a> of 	<a href="#otherAnchor">links</a>. Some are 	<a href="http://wherever.com/page.html">external</a>	and some are <a href="#someAnchor">local</a></p><input type=button value="Find Local Links" onclick="showLocalLinks('someText')">			

이것은 이 문법에 완전히 빠지도록 하기 위한 몇가지 예제를 가진다. 사용가능한 모든 함수를 위해 Enumerable and Array 참조문서를 보라.

toc

내가 강력하게 추천하는 책들.

다음의 책들은 AJAX애플리케이션을 만들기 위해 요구되는 새로운 스킬을 배우는데 많은 도움을 주었고 이미 알고 있던 스킬을 좀더 탄탄하게 만들어주었다. 나는 좋은 책이 충분히 금적적인 가치를 하고 오랜시간동안 가치를 이어간다고 생각한다.

toc


prototype.js 참조

JavaScript 클래스에 대한 확장

prototype.js라이브러리에 기능을 추가하기 위한 방법중 하나는 현재 존재하는 JavaScript클래스를 확장하는 것이다.

toc

Object 클래스를 위한 확장

메소드종류인자상세설명
extend(destination, source)staticdestination: 객체, source: 객체source에서 destination으로 모든 프라퍼티와 메소드를 복사하여 상속을 구현하기 위한 방법을 제공
inspect(targetObj)statictargetObj: 객체targetObj의 사람이 읽을수 있는 문자열 표현으로 반환. 주어진 객체가 inspect 인스턴스 메소드를 정의하지 않는다면, toString 의 값을 반환

toc

Number 클래스를 위한 확장

메소드종류인자상세설명
toColorPart()instance(none)숫자의 16진법 표현을 반환. 색상의 RGB컴포넌트를 HTML표현으로 변환할때 유용
succ()instance(none)다음 숫자를 반환. 이 함수는 반복을 포함하는 시나리오에서 사용된다.
times(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체인자 valueindex를 반복적으로 전달하는 iterator 함수를 호출하는 것은 iteration과 현재 index내 현재 값을 각각 포함한다.

다음의 예제는 0에서 9까지의 메시지 박스를 표시할것이다.

<script>	function demoTimes(){		var n = 10;		n.times(function(index){			alert(index);		});		/***************************		 * you could have also used: 		 *           (10).times( .... ); 		 ***************************/	}</script><input type=button value="Test Number.times()" onclick="demoTimes()">			

toc

Function 클래스를 위한 확장

메소드종류인자상세설명
bind(object)instanceobject: 메소드를 소유하는 객체함수(=메소드) 소유자 객체로 미리 묶는 함수의 인스턴스를 반환. 반환된 함수는 원래의 것과 같은 인자를 가질것이다.
bindAsEventListener(object)instanceobject: 메소드를 소유하는 객체유하는 객체 함수(=메소드) 소유자 객체로 미리 묶는 함수의 인스턴스를 반환. 반환된 함수는 이것의 인자로 현재 이벤트 객체를 가질것이다.

실제로 이 확장중 하나를 보자.

<input type=checkbox id=myChk value=1> Test?<script>	//declaring the class	var CheckboxWatcher = Class.create();	//defining the rest of the class implementation	CheckboxWatcher.prototype = {	   initialize: function(chkBox, message) {			this.chkBox = $(chkBox);			this.message = message;			//assigning our method to the event			
this.chkBox.onclick = this.showMessage.bindAsEventListener(this);
}, showMessage: function(evt) { alert(this.message + ' (' + evt.type + ')'); } }; var watcher = new CheckboxWatcher('myChk', 'Changed');</script>

toc

String 클래스를 위한 확장

메소드종류인자상세설명
stripTags()instance(none)HTML이나 XML태그가 삭제된 문자열을 반환
stripScripts()instance(none)삭제된 <script /> 블럭을 가진 문자열을 반환
escapeHTML()instance(none)HTML마크업 문자들이 escaped된 문자열 반환
unescapeHTML()instance(none)escapeHTML()의 반대
extractScripts()instance(none)문자열내에서 발견되는 모든 <script />블럭을 포함하는 Array객체 반환
evalScripts()instance(none)문자열내에서 발견되는 각각의 <script />블럭을 평가하기
toQueryParams()instance(none)쿼리문자열(querystring)을 파라미터 이름에 의해 인덱스화되는 결합된 Array로 쪼개기
parseQuery()instance(none)toQueryParams()와 같음.
toArray()instance(none)문자열을 이것의 문자들의 Array로 쪼개기
camelize()instance(none)-(하이픈)으로 분리된 문자열을 camelCaseString으로 변환하기. 이 함수는 예를 들면, 프라퍼티 스타일을 다루는 코드를 작성할때 유용하다.

toc

Array 클래스를 위한 확장

시작하기 위해, ArrayEnumerable를 확장한다. 그래서 Enumerable객체내에 정의되는 모든 편리한 메소드는 사용가능하다. 이것외에도, 아래의 메소드들이 구현되었다.

메소드종류인자상세설명
clear()instance(none)배열을 비우고 자체를 반환한다.
compact()instance(none)null 이거나 undefined인 요소를 제외하고 배열을 반환한다. 이 메소드는 배열자체를 변경하지 않는다.
first()instance(none)배열의 첫번째 요소를 반환한다.
flatten()instance(none)기복이 없고, 1차원의 배열을 반환한다. 이 함수는 배열이고 반환된 배열내 요소를 포함하는 배열의 각 요소를 찾음으로써 수행된다.
indexOf(value)instancevalue: 당신이 찾는 것배열에서 찾아진다면 주어진 value의 0부터 시작하는 인덱스의 위치를 반환. value이 없다면 -1을 반환
inspect()instance(none)요소를 가진 배열의 잘 포맷팅된 문자열 표시를 반환하기 위해 변경
last()instance(none)배열의 마지막 요소를 반환한다.
reverse([applyToSelf])instanceapplyToSelf: 배열 자체가 반전되는지 표시역순서로 배열을 반환. 인자가 주어지지 않거나 인자가 true라면, 배열자체는 반전될것이다. 그렇지 않으면 변경되지 않고 남는다.
shift()instance(none)첫번째 요소를 반환하고 배열로부터 이것을 제거한다. 배열의 길이는 1 감소한다.
without(value1 [, value2 [, .. valueN]])instancevalue1 ... valueN: 배열내 존재한다면 제외될 값인자로 주어진 요소를 제외한 배열을 반환

toc

document DOM 객체를 위한 확장

메소드종류인자상세설명
getElementsByClassName(className [, parentElement])instanceclassName: 요소와 연관된 CSS클래스 이름, parentElement: 객체 또는 가져올 요소를 포함하는 요소의 id.주어진 CSS클래스명과 연관된 모든 요소를 반환. parentElement id가 주어졌다면, 전체 문서가 검색될것이다.

toc

Event 객체를 위한 확장

프라퍼티타입상세설명
KEY_BACKSPACENumber8: 되돌리기(<-) 키를 위한 상수 코드.
KEY_TABNumber9: 탭키를 위한 상수코드
KEY_RETURNNumber13: 리턴키를 위한 상수코드
KEY_ESCNumber27: Esc키를 위한 상수코드
KEY_LEFTNumber37: 왼쪽 화살표 키를 위한 상수코드
KEY_UPNumber38: 위쪽 화살표 키를 위한 상수코드
KEY_RIGHTNumber39: 오른쪽 화살표 키를 위한 상수코드
KEY_DOWNNumber40: 아래쪽 화살표 키를 위한 상수코드
KEY_DELETENumber46: Delete키를 위한 상수코드
observers:Array캐시된 관찰자(observers)의 목록. 상세한 객체의 내부구현의 일부

메소드종류인자상세설명
element(event)staticevent: 이벤트 객체이벤트를 일으키는 요소를 반환
isLeftClick(event)staticevent: 이벤트 객체마우스 왼쪽 버튼을 클릭시 true값 반환
pointerX(event)staticevent: 이벤트 객체페이지에서 마우스 포인터의 x측 좌표값 반환
pointerY(event)staticevent: 이벤트 객체페이지에서 마우스 포인터의 y측 좌표값 반환
stop(event)staticevent: 이벤트 객체이벤트의 디폴트 행위를 취소하고 위임을 연기하기 위해 이 함수를 사용
findElement(event, tagName)staticevent: 이벤트 객체, tagName: 원하는 태그명DOM트리 위쪽으로 가로지른다. 주어진 태그명을 가진 첫번째 요소를 검색한다. 이벤트를 발생시키는 요소로부터 시작한다.
observe(element, name, observer, useCapture)staticelement: 객체 또는 아이디, name: 이벤트 명 (like 'click', 'load', etc), observer: 이벤트를 다루는 함수, useCapture: true라면, capture내 이벤트를 다루고 false라면 bubbling 내 이벤트를 다룬다.이벤트를 위한 이벤트 핸들러 함수를 추가
stopObserving(element, name, observer, useCapture)staticelement: 객체 또는 아이디, name: 이벤트 명 ('click' 처럼), observer: 이벤트를 다루는 함수, useCapture: true라면 capture내 이벤트를 다루고, false라면 bubbling내에서 다룬다.이벤트로부터 이벤트 핸들러를 제거
_observeAndCache(element, name, observer, useCapture)staticprivate메소드, 이것에 대해 걱정하지말라.
unloadCache()static(none)private메소드, 이것에 대해 걱정하지말라. 메모리로부터 캐시된 모든 관찰자(observer)를 지운다.

window객체의 이벤트를 로그하기 위한 이벤트 핸들러를 추가하는 객체를 사용하는 방법을 보자.

<script>	Event.observe(window, 'load', showMessage, false);	function showMessage() {	  alert('Page loaded.');	}</script>						

toc

prototype.js에 새롭게 정의된 객체와 클래스

라이브러리가 당신을 돕는 다른 방법은 객체지향 디자인과 공통적인 기능을 위한 지원 모두를 구현하는 많은 객체를 제공하는 것이다.

toc

PeriodicalExecuter 객체

이 객체는 주어진 함수를 주어진 시간간격으로 반복적으로 호출하기 위한 로직을 제공한다.

메소드종류인자상세설명
[ctor](callback, interval)constructorcallback: 파라미터 성격이 아닌 함수, interval: 초단위 시간간격함수를 반복적으로 호출할 이 객체의 하나의 인스턴스를 생성

프라퍼티타입상세설명
callbackFunction()호출되기 위한 함수. 이 함수로 전달될 파라미터는 없다.
frequencyNumber이것은 수초내 간격으로 실질적으로 작용
currentlyExecutingBoolean만약 함수 호출이 진행중이라면 표시

toc

Prototype 객체

Prototype 객체는 사용되는 라이브러리의 버전을 명시하는 것보다 중요한 역활을 가지지 않는다.

프라퍼티타입상세설명
VersionString라이브러리의 버전
emptyFunctionFunction()비어있는(empty) 함수 객체
KFunction(obj)주어진 파라미터를 되돌리는 함수 객체
ScriptFragmentString스크립트를 확인하는 정규식 표현

toc

Enumerable 객체

Enumerable 객체는 list형태의 구조내에서 항목을 반복하기 위한 좀더 멋진 코드를 작성하는 것을 허용한다.

많은 객체들은 유용한 인터페이스에 영향을 끼치기 위해 Enumerable 을 확장한다.

프라퍼티타입상세설명
VersionString라이브러리의 버전

메소드종류인자상세설명
each(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체주어진 iterator함수를 호출하는 것은 첫번째 인자내 목록으로 각각의 요소와 두번째 인자내 요소의 인덱스 전달한다.
all([iterator])instanceiterator: Function(value, index)를 충족하는 함수 객체이 함수는 주어진 함수를 사용하여 값들의 전체 집합을 테스트하기 위한 방법이다. iterator 함수가 어떤 요소를 위해 falsenull을 반환한다면, all은 false를 반환할것이다. 그렇지 않다면 true를 반환할것이다. iterator가 주어지지 않는다면, 요소 자체가 falsenull이 아닌지 테스트할것이다. 당신은 "모든 요소가 false가 아닌지 체크한다"와 같이 이것을 읽을수 있다.
any(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체(선택사항)이 함수는 주어진 함수를 사용하여 값들의 전체 집합을 테스트하기 위한 방법이다. iterator함수가 어떤 요소를 위해 falsenull을 반환하지 않는다면 anytrue를 반환할것이다. 그렇지 않다면 false를 반환할것이다. iterator가 주어지지 않는다면, 요소 자체가 falsenull이 아닌지 테스트할것이다. 당신은 "어느 요소가 false가 아닌지 체크한다"와 같이 이것을 읽을수 있다.
collect(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 각각의 요소를 위한 iterator함수를 호출하고 Array로 각각의 결과를 반환한다. 집합내 각각의 요소를 위한 하나의 결과 요소는 같은 순서이다.
detect(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 각각의 요소를 위한 iterator함수를 호출하고 true를 반환하는 iterator함수를 야기하는 첫번째 요소를 반환한다. true를 반환하는 요소가 없다면, detect는 null을 반환한다.
entries()instance(none)toArray()와 같다.
find(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체detect()와 같다.
findAll(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 각각의 요소를 위한 iterator함수를 호출하고 true로 해석되는 값을 반환하는 iterator함수를 야기하는 모든 요소를 가진 Array을 반환한다. 이 함수는 reject()와는 반대의 함수이다.
grep(pattern [, iterator])instancepattern: 요소를 일치시키기 위해 사용되는 RegExp객체, iterator: Function(value, index)를 충족하는 함수 객체집합내 각각의 요소의 문자열 값을 pattern 정규표현식에 대해 테스트한다. 함수는 정규표현식에 대응되는 모든 요소를 포함하는 Array 를 반환할것이다. iterator함수가 주어진다면, Array는 대응되는 각각의 요소를 가진 iterator를 호출한 결과를 포함할것이다.
include(obj)instanceobj: 객체집합내 주어진 객체를 찾도록 시도한다. 객체가 찾아진다면, true를 반환하고 찾지 못한다면 false를 반환한다.
inject(initialValue, iterator)instanceinitialValue: 초기화 값처럼 사용되는 객체, iterator: Function(accumulator, value, index)를 충족하는 함수 객체iterator함수를 사용하여 집합의 모든 요소를 조합한다. 호출된 iterator는 accumulator인자에서 이전 반복의 결과를 전달한다. 첫번째 반복은 accumulator인자내 initialValue를 가진다. 마지막 결과는 마지막 반환값이다.
invoke(methodName [, arg1 [, arg2 [...]]])instancemethodName: 각각의 요소내에서 호출될 메소드의 이름, arg1..argN: 메소드 호출로 전달될 인자.집합의 각각의 요소내 methodName에 의해 명시되는 메소드를 호출하는 것은 주어진 인자(arg1에서 argN) 전달하고 Array객체로 결과를 반환한다.
map(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체collect()과 같다.
max([iterator])instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 가장 큰 값이나 iterator가 주어진다면 집합내 각각의 요소를 위한 iterator호출의 가장 큰 결과를 반환한다.
include(obj)instanceobj: 객체include()과 같다.
min([iterator])instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 가장 작은 값을 가진 요소나 iterator가 주어진다면 집합내 각각의 요소를 위한 iterator호출의 가장 작은 결과를 가진 요소를 반환한다.
partition([iterator])instanceiterator: Function(value, index)를 충족하는 함수 객체두개의 다른 배열을 포함하는 Array를 반환한다. 첫번째 배열은 true를 반환하는 iterator함수를 야기하는 모든 요소를 포함할것이고 두번째 배열은 남아있는 요소를 포함할것이다. 만약 iterator가 주어지지 않는다면, 첫번째 배열은 true로 해석하는 요소를 포함할것이고 다른 배열은 남아있는 요소를 포함할것이다.
pluck(propertyName)instancepropertyName : 각각의 요소로부터 읽어들이는 프라퍼티의 이름. 이것은 요소의 인덱스를 포함할수 있다.집합의 각각의 요소내 propertyName에 의해 명시된 프라퍼티에 값을 가져가고 Array객체로 결과를 반환한다.
reject(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체집합내 각각의 요소를 위한 iterator함수를 호출하고 false로 해석하는 값을 반환하는 iterator함수를 야기하는 모든 요소를 가진 Array를 반환한다. 이 함수는 findAll()과는 반대되는 함수이다..
select(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체findAll()과 같다.
sortBy(iterator)instanceiterator: Function(value, index)를 충족하는 함수 객체iterator함수 호출결과를 따르는 정렬된 모든 요소를 가진 Array을 반환.
toArray()instance(none)집합의 모든 요소를 가지는 Array를 반환.
zip(collection1[, collection2 [, ... collectionN [,transform]]])instancecollection1 .. collectionN: 병합될 목록, transform: Function(value, index)를 충족하는 함수 객체현재의 집합으로 각각의 주어진 집합을 병합한다. 이 병합 작업은 같은 수의 요소를 가진 새로운 배열을 반환한다. 현재 집합과 각각의 요소가 각각의 병합된 집합으로부터 같은 인덱스를 가진 요소의 배열(이것을 하위 배열이라고 부르자.)이다. transform함수가 주어진다면, 각각의 하위 배열은 반환되기 전에 이 함수에 의해 변형딜것이다. 빠른 예제 : [1,2,3].zip([4,5,6], [7,8,9]).inspect() 는 "[[1,4,7],[2,5,8],[3,6,9] ]" 를 반환한다.

toc

Hash 객체

Hash 객체는 hash구조를 구현한다. 이를테면, Key:Value쌍의 집합.

Hash객체내 각각의 항목은 두개의 요소(첫번째는 key, 두번째는 value)를 가진 배열이다. 각각의 항목은 두개의 프라퍼티(keyvalue)를 가진다.

메소드종류인자상세설명
keys()instance(none)모든 항목의 key를 가진 Array을 반환
values()instance(none)모든 항목의 value를 가진 Array을 반환
merge(otherHash)instanceotherHash: Hash 객체hash와 전달된 다른 hash를 조합하고 새로운 결과 hash를 반환
toQueryString()instance(none)쿼리 문자열처럼 포맷팅된 문자열로 hash의 모든 항목을 반환. 이를테면 'key1=value1&key2=value2&key3=value3'
inspect()instance(none)key:value쌍을 가진 hash의 포맷팅된 문자열 표현을 반환하기 위해 변경(오버라이드)

toc

ObjectRange 클래스

Enumerable으로부터 상속

상위 경계나 하위 경계로 값들의 범위를 표시

프라퍼티타입종류상세설명
start(any)instance범위의 시작값
end(any)instance범위의 마지막값
exclusiveBooleaninstance경계자체가 범위의 일부인지 판단

메소드종류인자상세설명
[ctor](start, end, exclusive)constructorstart: 시작값, end: 마지막값, exclusive: 경계가 범위내 포함되는가.?하나의 range객체를 생성한다. start 에서 end로 범위를 지정한다. startend가 같은 타입의 객체이고 succ()메소드를 가져야만 한다.
include(searchedValue)instancesearchedValue: 검색할 값주어진 값이 범위내 값인지 체크. truefalse값을 반환한다.

toc

Class 객체

Class 객체는 라이브러리에서 다른 클래스를 선언할때 사용된다. 클래스를 선언할때 이 객체를 사용하는 것은 생성자로 제공되는 initialize()메소드를 지원하기 위한 새로운 클래스를 발생시킨다.

아래의 샘플을 보라.

//declaring the classvar MySampleClass = Class.create();//defining the rest of the class implmentationMySampleClass.prototype = {   initialize: function(message) {		this.message = message;   },   showMessage: function(ajaxResponse) {      alert(this.message);   }};	//now, let's instantiate and use one objectvar myTalker = new MySampleClass('hi there.');myTalker.showMessage(); //displays alert			

메소드종류인자상세설명
create(*)instance(any)새로운 클래스를 위한 생성자를 정의

toc

Ajax 객체

이 객체는 AJAX기능을 제공하는 많은 다른 클래스를 위한 root와 명명공간(namespace)처럼 제공한다.

프라퍼티타입종류상세설명
activeRequestCountNumberinstance진행중인 AJAX요청의 수.

메소드종류인자상세설명
getTransport()instance(none)새로운 XMLHttpRequest 객체를 반환

toc

Ajax.Responders 객체

Enumerable로 부터 상속되었다

이 객체는 Ajax관련 이벤트가 발생할때 호출될 객체의 목록을 보존한다. 예를 들어, 당신이 AJAX작업을 위한 전역 예외 핸들러를 연결하길 원한다면 이 객체를 사용할수 있다.

프라퍼티타입종류상세설명
respondersArrayinstance객체의 목록은 AJAX이벤트 알림(notifications)을 위해 등록되었다..

메소드종류인자상세설명
register(responderToAdd)instanceresponderToAdd: 호출될 메소드를 가진 객체responderToAdd인자를 전달하는 객체는 AJAX이벤트(이를테면, onCreate, onComplete, onException 등등)처럼 명명된 메소드를 포함해야만 한다. 유사한 이벤트가 발생하면, 적절한 이름을 가진 메소드를 포함하는 모든 등록된 객체가 호출되는 메소드를 가질것이다.
unregister(responderToRemove)instanceresponderToRemove: list로부터 제거될 객체responderToRemove 인자로 전달되는 객체는 등록된 객체의 list로부터 제거될것이다.
dispatch(callback, request, transport, json)instancecallback: 보고되는 AJAX이벤트 이름, request: 이벤트를 책임지는 the Ajax.Request 객체, transport: AJAX호출을 가지는 XMLHttpRequest 객체, json: 응답의 X-JSON 헤더(존재할때만) 등록된 객체의 목록을 통해 실행하는 것은 callback 인자내 결정된 메소드를 가지는 것을 찾는다. 호출되는 각각의 메소드는 다른 3개의 인자를 전달한다. AJAX응답이 몇몇 JSON컨텐츠를 가지는 X-JSON HTTP 헤더를 포함한다면, 이것은 평가되고 json인자로 전달될것이다. 만약 이벤트가 onException라면, transport인자는 대신에 예외를 가질것이고 json은 전달되지 않을것이다.

toc

Ajax.Base 클래스

이 클래스는 Ajax객체내 정의된 다른 대부분의 클래스를 위한 기본(base)클래스처럼 사용된다.

메소드종류인자상세설명
setOptions(options)instanceoptions: AJAX 옵션AJAX작업을 위해 필요한 옵션 셋팅
responseIsSuccess()instance(none)만약 AJAX작업이 성공한다면 true를 반환하고, 실패한다면 false를 반환
responseIsFailure()instance(none)responseIsSuccess()와는 반대.

toc

Ajax.Request 클래스

Ajax.Base로 부터 상속

AJAX 작업을 캡슐화

프라퍼티타입종류상세설명
EventsArraystaticAJAX작업중 보고되는 가능한 이벤트/상태의 목록. 목록은 'Uninitialized', 'Loading', 'Loaded', 'Interactive', 그리고 'Complete.'를 포함한다.
transportXMLHttpRequestinstanceAJAX작업을 가지는 XMLHttpRequest 객체
urlStringinstance요청에 의해 대상이 되는 URL

메소드종류인자상세설명
[ctor](url, options)constructorurl: 꺼내기 위한 url, options: AJAX 옵션주어진 옵션을 사용하여 주어진 url을 호출할 이 객체의 하나의 인스턴스를 생성. 중요사항: 선택된 url은 브라우저의 보안 셋팅을 위한 대상이 될 가치가 없다. 많은 경우 브라우저는 현재 페이지처럼 같은 호스트로부터가 아니라면 url을 가져오지 않을것이다. 당신은 설정을 피하거나 사용자의 브라우저를 제한하기 위한 로컬 url만을 사용할 것이다.
evalJSON()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 AJAX응답내 존재하는 X-JSON HTTP헤더의 컨텐츠를 평가하기 위해 내부적으로 호출된다.
evalReponse()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. AJAX응답이 text/javascriptContent-type헤더를 가진다면, 응답 몸체는 평가되고 이 메소드는 사용될것이다.
header(name)instancename: HTTP 헤더명이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 AJAX응답의 HTTP헤더의 컨텐츠를 가져오기 위해 내부적으로 호출된다.
onStateChange()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 AJAX호출 상태 변경시 객체 자체에 의해 호출된다.
request(url)instanceurl: AJAX호출을 위한 url이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 생성자를 호출하는 동안 벌써 호출되었다.
respondToReadyState(readyState)instancereadyState: 상태 숫자값(1 에서 4)이 메소드는 대개 외부에서 호출되지 않는다. 이것은 AJAX호출 상태가 변경될때 객체 자체에 의해 호출된다.
setRequestHeaders()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 HTTP요청을 하는 동안 보내어질 HTTP헤더를 조합하기 위한 객체 스스로에 의해 호출된다.

toc

options 인자 객체

AJAX작업의 중요한 부분은 options 인자이다. 이것은 기대되는 프라퍼티를 가지는 동안 어떠한 객체도 전달될수 있다. 이것은 AJAX호출을 위해 익명 객체를 생성하는 것이 공통적이다.

프라퍼티타입디폴트상세설명
methodString'post'HTTP요청의 메소드
parametersString''요청에 전달한 값들의 url형태의 목록
asynchronousBooleantrueAJAX호출이 비동기적으로 만들어지는지 표시
postBodyStringundefinedHTTP POST의 경우 요청의 몸체내 전달되는 내용
requestHeadersArrayundefined요청과 함께 전달되기 위한 HTTP헤더의 목록. 이 목록은 많은 수의 항목을 가져야 한다. 나머지 항목은 사용자 정의 헤더의 이름이다. 그리고 다음의 항목은 헤더의 문자열 값이다. 예제 : ['my-header1', 'this is the value', 'my-other-header', 'another value']
onXXXXXXXXFunction(XMLHttpRequest)undefined각각의 이벤트/상태가 AJAX호출이 발생하는 동안 도착할때 호출될 사용자정의 함수. 예제 var myOpts = {onComplete: showResponse, onLoaded: registerLoaded};. 사용되는 함수는 AJAX작업을 가지는 XMLHttpRequest객체를 포함하는 하나의 인자를 받을것이다.
onSuccessFunction(XMLHttpRequest)undefinedAJAX호출이 성공적으로 완성될때 호출될 사용자정의 함수. 사용되는 함수는 AJAX작업을 가지는 XMLHttpRequest객체를 포함하는 하나의 인자를 받을것이다.
onFailureFunction(XMLHttpRequest)undefinedAJAX호출이 에러를 가진채 끝날때 호출될 사용자정의 함수. 사용되는 함수는 AJAX작업을 가지는 XMLHttpRequest객체를 포함하는 하나의 인자를 받을것이다.
insertionFunction(Object, String)null삽입하기 위해 호출되는 함수는 텍스트를 요소로 반환한다. 함수는 수정되기 위한 요소객체와 Ajax.Updater객체에만 적용되는 응답 텍스트의 두개의 인자를 가지고 호출된다.
evalScriptsBooleanundefined, false스크립트 블럭이 응답이 도착했을때 평가할지를 판단. Ajax.Updater객체에만 적용.
decayNumberundefined, 1Ajax.PeriodicalUpdater 객체는 받은 응답이 마지막 것과 같을때 비율을 새롭게 하여 연속적인 후퇴를 결정. 예를 들어, 당신이 2를 사용한다면, 새롭게 된것중에 하나가 이전것과 같은 결과를 만든후에, 객체는 다음 refresh를 위한 시간의 두배를 기다릴것이다. 이것은 다시 반복한다면, 객체는 4배를 기다릴것이다. 이것을 후퇴를 피하기 위해 정의되지 않거나 1을 사용하도록 남겨두라.
frequencyNumberundefined, 2초단위의 갱신간격(횟수가 아닌), Ajax.PeriodicalUpdater객체에만 적용.

toc

Ajax.Updater 클래스

Ajax.Request로 부터 상속

요청된 url이 당신 페이지의 특정 요소내 직접적으로 삽입하길 원하는 HTML을 반환할때 사용된다. 당신은 url이 도착을 평가할 <script>블럭을 반환할때 이 객체를 사용할수 있다. 스크립트로 작업하기 위해 evalScripts 옵션을 사용하라.

프라퍼티타입종류상세설명
containersObjectinstance이 객체는 두개의 프라퍼티(containers.success 는 AJAX호출이 성공할때 사용될것이다. 그리고 AJAX호출이 실패한다면 containers.failure가 사용될것이다.)를 포함한다.

메소드종류인자상세설명
[ctor](container, url, options)constructorcontainer: 이것은 요소의 id, 요소객체 자체, 또는 두개의 프라퍼티(AJAX호출이 성공했을때 사용될 object.success 요소(또는 id), 그리고 AJAX호출이 실패했을때 사용될 object.failure요소(또는 id))를 가지는 객체가 될수 있다. url: 가져오기 위한 url, options: AJAX 옵션주어진 옵션을 사용하여 주어진 url을 호출할 이 객체의 하나의 인스턴스를 생성.
updateContent()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 응답을 받았을때 객체 자체에 의해 호출된다. 이것은 HTML로 적절한 요소를 수정하거나 insertion옵션내 전달되는 함수를 호출할것이다. 이 함수는 두개의 인자(수정되기 위한 요소와 응답 텍스트)를 가지고 호출될것이다.

toc

Ajax.PeriodicalUpdater 클래스

Ajax.Base로 부터 상속

이 클래스는 반복적으로 인스턴스화하고 페이지에서 요소를 새롭게 하거나 Ajax.Updater가 수행할수 있는 다른 작업중 어느것을 수행하기 위한 Ajax.Updater객체를 사용한다. 좀더 많은 정보를 위해 Ajax.Updater 참조를 체크하라.

프라퍼티타입종류상세설명
containerObjectinstance이 값은 Ajax.Updater생성자에 일관적으로 전달될것이다.
urlStringinstance이 값은 Ajax.Updater의 생성자에 일관적으로 전달될것이다.
frequencyNumberinstance초단위의 refresh간격. 디폴트는 2초. 이 숫자는 Ajax.Updater 객체를 호출할때 현재 축소(decay)에 의해 곱해질것이다.
decayNumberinstance작업을 재-수행할때 적용될 축소(decay)레벨을 유지
updaterAjax.Updaterinstance가장 최신에 사용된 Ajax.Updater 객체
timerObjectinstance다른 refresh를 위한 시각일때 객체를 알리기 위해 사용되는 자바스크립트 타이머

메소드종류인자상세설명
[ctor](container, url, options)constructoror container:이것은 요소의 id, 요소객체 자체, 또는 두개의 프라퍼티(AJAX호출이 성공할때 사용될 object.success 요소(나 id), AJAX호출이 실패할때 사용할 object.failure 요소(나 id))를 가지는 객체가 될수 있다. url: 가져오기 위한 url, options: AJAX 옵션주어진 옵션을 사용하여 주어진 url을 호출할 이 객체의 하나의 인스턴스를 생성
start()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것의 정기적인 작업 수행을 시작하기 위해 객체 자체에 의해 호출된다.
stop()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것의 정기적인 작업 수행을 시작하기 위해 객체 자체에 의해 호출된다.
updateComplete()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 요청을 완성한 후에 사용되는 Ajax.Updater에 의해 호출된다. 이것은 다음 refresh스케줄링 하기 위해 사용된다.
onTimerEvent()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 다음 수정을 위한 시각일때 내부적으로 호출된다.

toc

Element 객체

이 객체는 DOM내 요소를 변경하기 위해 몇몇 유틸리티성 함수들을 제공한다.

메소드종류인자상세설명
addClassName(element, className)instanceelement: element 객체 또는 아이디, className: CSS 클래스명주어진 class명을 요소의 class명으로 추가
classNames(element)instanceelement: element 객체 또는 아이디주어진 element와 관련된 CSS class명을 표시하는 Element.ClassNames 객체를 반환
cleanWhitespace(element)instanceelement: element 객체 또는 아이디요소의 자식노드에서 공백을 제거
empty(element)instanceelement: element 객체 또는 아이디element태그가 비어있는지(또는 공백만을 가지고 있는지) 표시하는 Boolean값을 반환
getDimensions(element)instanceelement: element 객체 또는 아이디element의 면적(dimensions)을 반환. 반환된 값은 두개의 프라퍼티(heightwidth)를 가지는 객체이다.
getHeight(element)instanceelement: element 객체 또는 아이디요소의 offsetHeight값을 반환
getStyle(element, cssProperty)instanceelement: element 객체 또는 아이디, cssProperty : CSS프라퍼티('prop-name' 또는 'propName' 가 작동하는 형태)의 이름주어진 element내 CSS프라퍼티의 값을 반환하거나 존재하지 않는다면 null 을 반환
hasClassName(element, className)instanceelement: element 객체 또는 아이디, className: CSS class명요소가 class명중에 하나로 주어진 class명을 가진다면 true를 반환
hide(elem1 [, elem2 [, elem3 [...]]])instanceelemN: element 객체 또는 아이디style.display'none'로 셋팅하여 각각의 요소를 숨긴다.
makeClipping(element)instanceelement: element 객체나 아이디
makePositioned(element)instanceelement: element 객체나 아이디element의 style.position'relative'로 변경
remove(element)instanceelement: element 객체 또는 아이디문서로 부터 요소를 제거한다.
removeClassName(element, className)instanceelement: element 객체 또는 아이디, className: CSS 클래스명요소의 class명으로 부터 주어진 class명을 제거
scrollTo(element)instanceelement: element 객체나 아이디창을 element위치로 스크롤
setStyle(element, cssPropertyHash)instanceelement: element 객체나 아이디, cssPropertyHash : 적용되기 위한 스타일을 가지는 Hash객체cssPropertyHash 인자내 값에 따라, 주어진 element내 CSS프라퍼티의 값을 셋팅.
show(elem1 [, elem2 [, elem3 [...]]])instanceelemN: element 객체 또는 아이디style.display''로 다시 셋팅하여 각각의 요소를 보여준다.
toggle(elem1 [, elem2 [, elem3 [...]]])instanceelemN: element 객체 또는 아이디각각의 전달된 요소의 가시성(visibility)을 토글(toggle)한다.
undoClipping(element)instanceelement: element 객체 또는 아이디
undoPositioned(element)instanceelement: element 객체 또는 아이디element의 style.position''으로 초기화
update(element, html)instanceelement: element 객체 또는 아이디, html: html 컨텐츠주어진 html인자를 가지는 요소의 내부 html을 대체. 주어진 html이 <script>블럭을 포함한다면, 그것들은 포함되지는 않지만 평가될것이다.
visible(element)instanceelement: element 객체 또는 아이디요소가 눈에 보이는지 표시하는 Boolean값을 반환

toc

Element.ClassNames class

Enumerable로부터 상속

element에 관련된 CSS class명의 collection을 표시

메소드종류인자상세설명
[ctor](element)constructorelement: DOM element 객체또는 아이디주어진 element의 CSS class명을 표시하는 Element.ClassNames 객체를 생성
add(className)instanceclassName: CSS class 명element에 관련된 class명의 리스트에 주어진 CSS class명을 추가
remove(className)instanceclassName: CSS class 명element에 관련된 class명의 리스트로부터 주어진 CSS class명을 제거
set(className)instanceclassName: CSS class 명주어진 CSS class명을 가진 element을 결합, element로부터 다른 class명을 제거.

toc

The Abstract 객체

이 객체는 라이브러리내 다른 클래스를 위한 root처럼 제공한다. 이것은 어떤 프라퍼티나 메소드도 가지지 않는다. 이 객체에 정의된 클래스는 전통적인 추상 클래스처럼 처리된다.

toc

Abstract.Insertion 클래스

이 클래스는 동적으로 내용물을 추가할 다른 클래스를 위한 기본 클래스처럼 사용된다. 이 클래스는 추상 클래스처럼 사용된다.

메소드종류인자상세설명
[ctor](element, content)constructorelement: element 객체 또는 아이디, content: 삽입되는 HTML동적 내용물 삽입을 도울 객체를 생성
contentFromAnonymousTable()instance(none)

프라퍼티타입종류상세설명
adjacencyStringstatic, parameter내용물이 주어진 요소에 대해 상대적으로 위치할 지점을 명시하는 파라미터. 가능한 값은 'beforeBegin', 'afterBegin', 'beforeEnd', 그리고 'afterEnd'.
elementObjectinstance삽입이 상대적으로 만들어질 요소객체
contentStringinstance삽입될 HTML.

toc

Insertion 객체

이 객체는 라이브러리내 다른 클래스를 위한 root처럼 제공한다. 이것은 어떠한 프라퍼티나 메소드를 가지지 않는다. 이 객체에 정의된 클래스는 전통적인 추상 클래스처럼 처리된다.

toc

Insertion.Before 클래스

Abstract.Insertion로 부터 상속

요소 앞에 HTML삽입

메소드종류인자상세설명
[ctor](element, content)constructorelement: element 객체 또는 아이디, content: 삽입되는 HTMLAbstract.Insertion으로 부터 상속. 동적으로 내용물을 삽입하는 것을 돕는 객체를 생성

다음의 코드는

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going?</span><script> new Insertion.Before('person', 'Chief '); </script>			

다음처럼 HTML이 변경될것이다.

<br>Hello, Chief <span id="person" style="color:red;">Wiggum. How's it going?</span>				

toc

Insertion.Top 클래스

Abstract.Insertion로 부터 상속

요소아래의 첫번째 자식으로 HTML을 삽입. 이 내용물은 요소의 열기 태그뒤에 위치할것이다.

메소드종류인자상세설명
[ctor](element, content)constructorelement: element 객체 또는 아이디, content: 삽입되는 HTMLAbstract.Insertion으로부터 상속. 동적으로 내용물을 삽입하는 것을 돕는 객체 생성

다음의 코드는

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going?</span><script> new Insertion.Top('person', 'Mr. '); </script>			

다음처럼 HTML이 변경될것이다.

<br>Hello, <span id="person" style="color:red;">Mr. Wiggum. How's it going?</span>				

toc

Insertion.Bottom 클래스

Abstract.Insertion로 부터 상속

요소아래의 마지막 자식으로 HTML삽입. 내용물은 요소의 닫기 태그앞에 위치할것이다.

메소드종류인자상세설명
[ctor](element, content)constructorelement: element 객체 또는 아이디, content: HTML to be insertedAbstract.Insertion로 부터 상속. 동적으로 내용물을 삽입하는 것을 돕는 객체 생성

다음의 코드는

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going?</span><script> new Insertion.Bottom('person', " What's up?"); </script>			

다음처럼 HTML이 변경될것이다.

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going? What's up?</span>				

toc

Insertion.After 클래스

Abstract.Insertion로 부터 상속

요소의 닫기 태그뒤 HTML삽입

메소드종류인자상세설명
[ctor](element, content)constructorelement: element 객체 또는 아이디, content: HTML to be insertedAbstract.Insertion으로부터 상속. 동적으로 내용물을 삽입하는 것을 돕는 객체 생성

다음의 코드는

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going?</span><script> new Insertion.After('person', ' Are you there?'); </script>			

다음처럼 HTML이 변경될것이다.

<br>Hello, <span id="person" style="color:red;">Wiggum. How's it going?</span> Are you there?				

toc

Field 객체

이 객체는 폼내 input필드와 작동하기 위한 몇가지 유틸리티성 함수를 제공한다.

메소드종류인자상세설명
clear(field1 [, field2 [, field3 [...]]])instancefieldN: field element 객체 또는 아이디 field요소로부터 각각 전달된 값을 지움(clear)
present(field1 [, field2 [, field3 [...]]])instancefieldN: field element 객체 또는 아이디 모든 폼 field가 빈값이 아니라면 true를 반환
focus(field)instancefield: field element 객체 또는 아이디주어진 폼 field로 입력 포커스 이동
select(field)instancefield: field element 객체 또는 아이디텍스트 선택을 지원하는 field내 값을 선택
activate(field)instancefield: field element 객체 또는 아이디포커스를 이동하고 텍스트 선택을 지원하는 field내 값을 선택

toc

Form 객체

이 객체는 데이터 항목 폼과 그것들의 입력 field와 작동하기 위한 몇몇 유틸리티성 함수를 제공한다.

메소드종류인자상세설명
serialize(form)instanceform: form element 객체 또는 아이디'field1=value1&field2=value2&field3=value3'처럼 field명과 값의 url형태의 목록을 반환
findFirstElement(form)instanceform: form element 객체 또는 아이디form에서 첫번째로 사용가능한 필드 element를 반환
getElements(form)instanceform: form element 객체 또는 아이디폼내 모든 입력 field를 포함하는 Array 반환
getInputs(form [, typeName [, name]])instanceform: form element 객체 또는 아이디, typeName: input요소의 타입, name: input요소명.폼내 모든 <input>요소를 포함하는 Array 반환. 선택적으로 목록은 요소의 타입이나 name속성에 의해 필터링 될수 있다.
disable(form)instanceform: form element 객체 또는 아이디폼내 모든 입력 field를 사용불가상태로 만들기
enable(form)instanceform: form element 객체 또는 아이디폼내 모든 입력 field를 사용가능하게 만들기
focusFirstElement(form)instanceform: form element 객체 또는 아이디첫번째 가시성을 활성화하고, 폼내 입력 field를 가능하게 하기
reset(form)instanceform: form element 객체 또는 아이디폼을 리셋하기. form객체의 reset()메소드와 같다.

toc

Form.Element 객체

이 객체는 폼요소와 작동하기 위한 몇몇 유틸리티성 함수를 제공한다.

메소드종류인자상세설명
serialize(element)instanceelement: element 객체 또는 아이디'elementName=elementValue'처럼 요소의 name=value 짝을 반환
getValue(element)instanceelement: element 객체 또는 아이디요소의 값을 반환

toc

Form.Element.Serializers 객체

이 객체는 폼요소의 현재 값을 가져오기 위해 라이브러리 내부적으로 사용되는 몇몇 유틸리티성 함수를 제공한다.

메소드종류인자상세설명
inputSelector(element)instanceelement: radio 버튼이나 checkbox처럼 checked프라퍼티를 가지는 form요소의 객체 또는 아이디['elementName', 'elementValue']처럼 요소의 이름과 값을 가지는 Array을 반환
textarea(element)instanceelement: textbox, button 또는 password필드처럼 value프라퍼티를 가지는 form요소의 객체 또는 아이디.['elementName', 'elementValue']처럼 요소의 이름과 값을 가지는 Array를 반환
select(element)instanceelement: <select> 요소의 객체 또는 아이디['elementName', 'selOpt1 selOpt4 selOpt9']처럼 요소의 이름과 모든 선택된 옵션의 값이나 텍스트를 가지는 Array를 반환

toc

Abstract.TimedObserver 클래스

이 클래스는 값이 변경(또는 프라퍼티가 클래스정의를 얻어내는)될때까지 하나의 요소를 모니터링할 다른 클래스를 위한 기본클래스처럼 사용된다. 이 클래스는 추상클래스처럼 사용된다.

하위클래스는 요소의 입력값, style프라퍼티중 하나, 또는 테이블내 row의 수, 또는 당신이 추적하고자 하는 모든것을 모니터링하기 위해 생성될수 있다.

얻어낸 클래스는 요소내 모니터링되는 현재 값을 무엇인지 판단하기 위한 메소드를 구현하는 것이다.

메소드종류인자상세설명
[ctor](element, frequency, callback)constructorelement: element 객체 또는 아이디, frequency: 초단위 간격, callback: 요소가 변경될때 호출되는 함수요소를 모니터링할 객체 생성
getValue()instance, abstract(none)
registerCallback()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 요소 모니터링릉 시작하기 위한 객체 자체에 의해 호출된다.
onTimerEvent()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 요소를 체크하기 위해 정기적으로 객체 자체에 의해 호출된다.

프라퍼티타입상세설명
elementObject모니터링되는 요소객체
frequencyNumber이것은 체크사이에 초단위 간격으로 이루어진다.
callbackFunction(Object, String)요소가 변경될때마다 호출되기 위한 함수. 이것은 요소객체와 새로운 값을 받을것이다.
lastValueString요소내 확인되는 마지막 값

toc

Form.Element.Observer 클래스

Abstract.TimedObserver로 부터 상속

폼 입력 요소의 값을 모니터링하는 Abstract.TimedObserver의 구현물. 값 변경을 보고하는 이벤트를 드러내지 않는 요소를 모니터링하고자 할때 이 클래스를 사용하라. 이 경우 당신은 Form.Element.EventObserver 클래스를 대신 사용할수 있다.

메소드종류인자상세설명
[ctor](element, frequency, callback)constructorelement: element 객체 또는 아이디, frequency: interval in seconds, callback: function to be called when the element changesAbstract.TimedObserver으로부터 상속. 요소의 value프라퍼티를 모니터링할 객체를 생성.
getValue()instance(none)요소의 값을 반환

toc

Form.Observer 클래스

Abstract.TimedObserver로 부터 상속

폼내 데이터 항목 요소의 값이 변경하는지를 모니터링하는 Abstract.TimedObserver의 구현물. 당신이 값 변경을 보고하는 이벤트를 드러내지 않는 요소를 포함하는 폼을 모니터링하고자 할때 이 클래스를 사용하라. 이 경우 당신은 Form.EventObserver 클래스를 대신 사용할수 있다.

메소드종류인자상세설명
[ctor](form, frequency, callback)constructorform: form 객체 또는 아이디, frequency: 초단위 간격, callback: form내 데이터 항목 요소가 변경될때 호출되는 함수Abstract.TimedObserver로부터 상속. 변경하기 위한 폼을 모니터링할 객체 생성.
getValue()instance(none)모든 폼의 데이터의 직렬화를 반환

toc

Abstract.EventObserver 클래스

이 클래스는 요소를 위해 값-변경 이벤트가 발생할때마다 콜백함수를 수행하는 다른 클래스를 위한 기본 클래스처럼 사용된다.

Abstract.EventObserver 타입의 다중 객체는 다른것을 지우지 않고 같은 요소로 묶일수 있다. 콜백은 요소에 할당되는 순서대로 수행될것이다.

트리거 형태의 이벤트는 radio버튼과 checkbox를 위해서는 onclick이고 대개의 textbox와 리스트박스/드랍다운을 위해서는 onchange이다.

얻어낸 클래스는 요소내 모니터링되는 현재 값을 무엇인지 판단하기 위한 메소드를 구현하는 것이다.

메소드종류인자상세설명
[ctor](element, callback)constructorelement: element 객체 또는 아이디, callback: 이벤트가 발생할때 호출되는 함수요소를 모니터링할 객체 생성.
getValue()instance, abstract(none)
registerCallback()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 요소의 이벤트를 자체적으로 묶는 객체에 의해 호출된다.
registerFormCallbacks()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 폼내 각각의 데이터 항목 요소의 이벤트로 자체적으로 묶기 위한 객체에 의해 호출된다.
onElementEvent()instance(none)이 메소드는 대개 외부적으로 호출되지 않는다. 이것은 요소의 이벤트로 묶일것이다.

프라퍼티타입상세설명
elementObject모니터링되는 요소객체
callbackFunction(Object, String)요소가 변경될때마다 호출되기 위한 함수. 이것은 요소객체와 새로운 값을 받을것이다.
lastValueString요소내 확인되는 마지막 값

toc

Form.Element.EventObserver 클래스

Abstract.EventObserver로 부터 상속

요소내 값 변경을 감지하기 위한 폼 데이터 항목 요소의 적절한 이벤트를 위한 콜백 함수를 수행하는 Abstract.EventObserver의 구현물. 만약 요소가 변경을 보고하는 이벤트를 드러내지 않는다면, 당신은 Form.Element.Observer 클래스를 대신 사용할수 있다.

메소드종류인자상세설명
[ctor](element, callback)constructorelement: element 객체 또는 아이디, callback: function to be called when the event happensAbstract.EventObserver로 부터 상속. 요소의 value프라퍼티를 모니터링할 객체 생성.
getValue()instance(none)요소의 값 반환.

toc

Form.EventObserver 클래스

Abstract.EventObserver로 부터 상속

값이 변결될때 감지하기 위한 요소의 이벤트를 사용하여 폼내 포함되는 어느 데이터 항목 요소에 변경을 모니터링하는 Abstract.EventObserver의 구현물. 만약 폼이 변경을 보고하는 이벤트를 드러내지 않는 요소를 포함한다면, 당신은 Form.Observer 클래스를 대신 사용할수 있다.

메소드종류인자상세설명
[ctor](form, callback)constructorform: form 객체 또는 아이디, callback: form내 데이터 항목 요소가 변경될때 호출되는 함수Abstract.EventObserver로부터 상속. 변경을 위해 폼을 모니터링할 객체 생성.
getValue()instance(none)모든 폼의 데이터 직렬화를 반환

toc

Position 객체 (예비 문서)

이 객체는 요소 위치할당을 작업할때 돕는 수많은 함수를 제공한다.

메소드종류인자상세설명
prepare()instance(none)스크롤 위치내 변경을 수용하기 위한 deltaXdeltaY 프라퍼티 조정. 페이지 스크롤후 withinIncludingScrolloffset를 호출하기 전에 이 메소드를 호출하는 것을 기억하라.
realOffset(element)instanceelement: object요소에 영향을 끼치는 어느 스크롤 offset를 포함하는 요소의 정확한 스크롤 offset를 가진 Array을 반환. 이 결과 배열은 [total_scroll_left, total_scroll_top]과 유사하다.
cumulativeOffset(element)instanceelement: object위치가 할당된 부모 요소에 의해 부과된 어느 offset를 포함하는 요소의 정확한 위치가 할당된 offset를 가진 Array을 반환. 결과 배열은 [total_offset_left, total_offset_top]과 유사하다.
within(element, x, y)instanceelement: object, x 와 y: 위치 조정만약 주어진 지점이 주어진 요소의 직사각형내 조정이 되는지 테스트.
withinIncludingScrolloffsets(element, x, y)instanceelement: object, x and y: coordinates of a point
overlap(mode, element)instancemode: 'vertical' 나 'horizontal', element: objectwithin()은 이 메소드가 호출되기 전에 호출될 필요가 있다. 이 메소드는 요소에서 겹치는 것을 조정하는 세분화정도를 표현하는 0.0과 1.0사이의 10진수를 반환할것이다. 예를 들면, 만약 요소가 100px를 가지는 정사각형 DIV이고 (300,300)에 위치한다면, within(divSquare, 330, 330); overlap('vertical', divSquare);은 DIV의 top border로부터 10%(30px)를 가리키는 것을 의미하는 0.10을 반환할것이다.
clone(source, target)instancesource: element 객체 또는 아이디, target: element 객체 또는 아이디source요소에 대해 똑같이 target요소의 크기를 다시 조정하고 다시 위치를 지정


1.4.0을 위한 이 문서는 여전히 작업중입니다. 이 문서의 업데이트를 계속 지켜봐주십시오.
만약 에러를 발견한다면, let me know나에게 알려주십시오. 그러면 가능한한 빨리 그것을 수정할것입니다.
한글 번역에 관련된 부분은 한국어 번역자으로 알려주십시오.

'IT' 카테고리의 다른 글

HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
Ajax: A New Approach to Web Applications  (0) 2006.08.22
script.aculous wiki 사이트  (0) 2006.08.14
Yahoo! Ajax UI 가이드 라인 무료 공개  (1) 2006.08.11
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

Yahoo! Open Sources UIs and Design Patterns Permalink
By nat on February 13, 2006

Kudos to Yahoo!, who today released two pieces of goodness into the commons. The first is their UI library, and the second is their Design Patterns Library. The UI Library is a collection of DHTML/Ajax/Javascript (pick your favourite term) controls and widgets. The Design Patterns Library is "intended to provide Web designers prescriptive guidance to help solve common design problems on the Web". I swear I didn't know they were going to do this when I wrote "I'd like to see some HIGs for Ajax interfaces" yesterday, but boy am I impressed! Best of all, Yahoo! gets open source licenses: the UI library is BSD and the Design Pattern library is Creative Commons Attribution 2.5.

Tags: yahoo ajax ui

Comments

I saw this pointed out elsewhere and I'm already using their pretty and easy calendar widget :-)

Very much kudos to Yahoo!

Posted by: Richard at February 13, 2006 07:53 PM

Awesome! Please post to the group at http://groups.yahoo.com/group/ydn-javascript/ and let us know how and where you're using it!

Posted by: Jeffrey McManus at February 13, 2006 08:20 PM

Great Job! Yahoo may decide to release them because they will be opened in web page at last. Nevertheless they took a trouble to make a documentation them. Also they consider accessiblity problems on Ajax interfaces.

Posted by: Channy at February 13, 2006 09:43 PM

Great job and great decision to share some cool widgets! Hope for good support as well.

Posted by: Andrew Bidochko at February 14, 2006 07:19 AM

I also recommend checking out the Yahoo! User Interface Blog and subscribing to the RSS feeds there.

Posted by: Douglas Clifton at February 14, 2006 08:46 PM

'IT' 카테고리의 다른 글

HTTP 에러 코드  (0) 2006.09.05
Top 10 Web Developer Libraries  (2) 2006.08.29
Ajax: A New Approach to Web Applications  (0) 2006.08.22
script.aculous wiki 사이트  (0) 2006.08.14
prototype.js 를 위한 개발자 노트  (0) 2006.08.14

+ Recent posts