The Calendar control exposes a number of CustomEvents, so that applications can listen for and react to interesting moments in the Calendar's operation. This example demonstrates how to listen for the select and deselect events, which are fired whenever a date in the Calendar is selected or deselected.
Calendar provides several events to which an application can subscribe in order to react easily to changes in the state of the Calendar. The events provided are:
The events are each defined by YAHOO.util.CustomEvent, and are subscribed to using the subscribe method of CustomEvent. In this example, we will display a message each time a date is selected or deselected. The selectEvent and deselectEvent events will fire when selections and deselections are made via user interaction (eg, when a user clicks to select a date) or programatically (eg., if a script on the page executes the select method to select a date).
The dateToLocaleString
function used to generate the messages demonstrates how you can use the locale configuration properties for Calendar when creating string representations of dates
1 | function dateToLocaleString(dt, cal) { |
2 | var wStr = cal.cfg.getProperty("WEEKDAYS_LONG")[dt.getDay()]; |
3 | var dStr = dt.getDate(); |
4 | var mStr = cal.cfg.getProperty("MONTHS_LONG")[dt.getMonth()]; |
5 | var yStr = dt.getFullYear(); |
6 | return (wStr + ", " + dStr + " " + mStr + " " + yStr); |
7 | } |
8 | |
9 | function mySelectHandler(type,args,obj) { |
10 | var selected = args[0]; |
11 | var selDate = this.toDate(selected[0]); |
12 | |
13 | logEvent("SELECTED: " + dateToLocaleString(selDate, this)); |
14 | }; |
15 | |
16 | function myDeselectHandler(type, args, obj) { |
17 | var deselected = args[0]; |
18 | var deselDate = this.toDate(deselected[0]); |
19 | |
20 | logEvent("DESELECTED: " + dateToLocaleString(deselDate, this)); |
21 | }; |
22 | |
23 | YAHOO.example.calendar.cal1 = new YAHOO.widget.Calendar("cal1","cal1Container"); |
24 | |
25 | YAHOO.example.calendar.cal1.selectEvent.subscribe(mySelectHandler, YAHOO.example.calendar.cal1, true); |
26 | YAHOO.example.calendar.cal1.deselectEvent.subscribe(myDeselectHandler, YAHOO.example.calendar.cal1, true); |
27 | |
28 | YAHOO.example.calendar.cal1.render(); |
view plain | print | ? |
You can load the necessary JavaScript and CSS for this example from Yahoo's servers. Click here to load the YUI Dependency Configurator with all of this example's dependencies preconfigured.
INFO 1063ms (+0) 7:54:58 PM:
Config
Firing Config event: iframe=false
INFO 1063ms (+0) 7:54:58 PM:
Config
Firing Config event: close=false
INFO 1063ms (+1) 7:54:58 PM:
Config
Firing Config event: title=
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-4-5)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell41 (2025-4-5)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-4-4)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell40 (2025-4-4)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-4-3)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell39 (2025-4-3)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-4-2)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell38 (2025-4-2)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-4-1)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell37 (2025-4-1)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-31)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-31)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell36 (2025-3-31)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-30)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-30)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell35 (2025-3-30)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-29)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-29)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell34 (2025-3-29)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-28)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-28)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell33 (2025-3-28)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-27)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-27)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell32 (2025-3-27)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-26)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-26)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell31 (2025-3-26)
CELL 1062ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-25)
CELL 1062ms (+1) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-25)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell30 (2025-3-25)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-24)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-24)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell29 (2025-3-24)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-23)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-23)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell28 (2025-3-23)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-22)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-22)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell27 (2025-3-22)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-21)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-21)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell26 (2025-3-21)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-20)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-20)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell25 (2025-3-20)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-19)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-19)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell24 (2025-3-19)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-18)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-18)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell23 (2025-3-18)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-17)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-17)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell22 (2025-3-17)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[2] for (2025-3-16)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-16)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-16)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell21 (2025-3-16)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-15)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-15)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell20 (2025-3-15)
CELL 1061ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-14)
CELL 1061ms (+1) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-14)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell19 (2025-3-14)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-13)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-13)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell18 (2025-3-13)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-12)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-12)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell17 (2025-3-12)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-11)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-11)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell16 (2025-3-11)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-10)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-10)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell15 (2025-3-10)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-9)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-9)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell14 (2025-3-9)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-8)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-8)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell13 (2025-3-8)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-7)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-7)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell12 (2025-3-7)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-6)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-6)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell11 (2025-3-6)
CELL 1060ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-5)
CELL 1060ms (+1) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-5)
CELL 1059ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell10 (2025-3-5)
CELL 1059ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-4)
CELL 1059ms (+0) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-4)
CELL 1059ms (+0) 7:54:58 PM:
Calendar cal1
Rendering cell cal1_cell9 (2025-3-4)
CELL 1059ms (+0) 7:54:58 PM:
Calendar cal1
renderer[1] for (2025-3-3)
CELL 1059ms (+1059) 7:54:58 PM:
Calendar cal1
renderer[0] for (2025-3-3)
INFO 0ms (+0) 7:54:56 PM:
global
Logger initialized
Note: You are viewing this example in debug mode with logging enabled. This can significantly slow performance.
Copyright © 2009 Yahoo! Inc. All rights reserved.
Privacy Policy - Terms of Service - Copyright Policy - Job Openings