123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235 |
- <div class="body-wrap">
- <div class="top-tools">
- <a class="inner-link" href="#Ext.KeyMap-props"><img src="../resources/images/default/s.gif" class="item-icon icon-prop">Properties</a>
- <a class="inner-link" href="#Ext.KeyMap-methods"><img src="../resources/images/default/s.gif" class="item-icon icon-method">Methods</a>
- <a class="inner-link" href="#Ext.KeyMap-events"><img src="../resources/images/default/s.gif" class="item-icon icon-event">Events</a>
- <a class="bookmark" href="../docs/?class=Ext.KeyMap"><img src="../resources/images/default/s.gif" class="item-icon icon-fav">Direct Link</a>
- </div>
- <h1>Class Ext.KeyMap</h1>
- <table cellspacing="0">
- <tr><td class="label">Package:</td><td class="hd-info">Ext</td></tr>
- <tr><td class="label">Defined In:</td><td class="hd-info"><a href="../src/KeyMap.js" target="_blank">KeyMap.js</a></td></tr>
- <tr><td class="label">Class:</td><td class="hd-info">KeyMap</td></tr>
- <tr><td class="label">Extends:</td><td class="hd-info">Object</td></tr>
- </table>
- <div class="description">
- Handles mapping keys to actions for an element. One key map can be used for multiple actions.
- The constructor accepts the same config object as defined by <a ext:cls="Ext.KeyMap" ext:member="addBinding" href="output/Ext.KeyMap.html#addBinding">addBinding</a>.
- If you bind a callback function to a KeyMap, anytime the KeyMap handles an expected key
- combination it will call the function with this signature (if the match is a multi-key
- combination the callback will still be called only once): (String key, Ext.EventObject e)
- A KeyMap can also handle a string representation of keys.<br />
- Usage:
- <pre><code><i>// map one key by key code</i>
- <b>var</b> map = <b>new</b> Ext.KeyMap(<em>"my-element"</em>, {
- key: 13, <i>// or Ext.EventObject.ENTER</i>
- fn: myHandler,
- scope: myObject
- });
- <i>// map multiple keys to one action by string</i>
- <b>var</b> map = <b>new</b> Ext.KeyMap(<em>"my-element"</em>, {
- key: <em>"a\r\n\t"</em>,
- fn: myHandler,
- scope: myObject
- });
- <i>// map multiple keys to multiple actions by strings and array of codes</i>
- <b>var</b> map = <b>new</b> Ext.KeyMap(<em>"my-element"</em>, [
- {
- key: [10,13],
- fn: <b>function</b>(){ alert(<em>"Return was pressed"</em>); }
- }, {
- key: <em>"abc"</em>,
- fn: <b>function</b>(){ alert(<em>'a, b or c was pressed'</em>); }
- }, {
- key: <em>"\t"</em>,
- ctrl:true,
- shift:true,
- fn: <b>function</b>(){ alert(<em>'Control + shift + tab was pressed.'</em>); }
- }
- ]);</code></pre>
- <b>Note: A KeyMap starts enabled</b> </div>
-
- <div class="hr"></div>
- <a id="Ext.KeyMap-props"></a>
- <h2>Public Properties</h2>
- <table cellspacing="0" class="member-table">
- <tr>
- <th class="sig-header" colspan="2">Property</th>
- <th class="msource-header">Defined By</th>
- </tr>
- <tr class="property-row expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-stopEvent"></a>
- <b>stopEvent</b> : Boolean <div class="mdesc">
- <div class="short">True to stop the event from bubbling and prevent the default browser action if the
- key was handled by the KeyMap (def...</div>
- <div class="long">
- True to stop the event from bubbling and prevent the default browser action if the
- key was handled by the KeyMap (defaults to false) </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- </table>
- <a id="Ext.KeyMap-methods"></a>
- <h2>Public Methods</h2>
- <table cellspacing="0" class="member-table">
- <tr>
- <th class="sig-header" colspan="2">Method</th>
- <th class="msource-header">Defined By</th>
- </tr>
- <tr class="method-row expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-KeyMap"></a>
- <b>KeyMap</b>( <code>Mixed el</code>, <code>Object config</code>, <span class="optional" title="Optional">[<code>String eventName</code>]</span> ) <div class="mdesc">
- <div class="short"></div>
- <div class="long">
- <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li><code>el</code> : Mixed<div class="sub-desc">The element to bind to</div></li><li><code>config</code> : Object<div class="sub-desc">The config (see <a ext:cls="Ext.KeyMap" ext:member="addBinding" href="output/Ext.KeyMap.html#addBinding">addBinding</a>)</div></li><li><code>eventName</code> : String<div class="sub-desc">(optional) The event to bind to (defaults to "keydown")</div></li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code></code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- <tr class="method-row alt expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-addBinding"></a>
- <b>addBinding</b>( <code>Object/Array config</code> ) : void <div class="mdesc">
- <div class="short">Add a new binding to this KeyMap. The following config object properties are supported:
- Property Type ...</div>
- <div class="long">
- Add a new binding to this KeyMap. The following config object properties are supported:
- <pre>Property Type Description
- ---------- --------------- ----------------------------------------------------------------------
- key String/Array A single keycode or an array of keycodes to handle
- shift Boolean True to handle key only when shift is pressed (defaults to false)
- ctrl Boolean True to handle key only when ctrl is pressed (defaults to false)
- alt Boolean True to handle key only when alt is pressed (defaults to false)
- handler Function The function to call when KeyMap finds the expected key combination
- fn Function Alias of handler (for backwards-compatibility)
- scope Object The scope of the callback function</pre>
- Usage:
- <pre><code><i>// Create a KeyMap</i>
- <b>var</b> map = <b>new</b> Ext.KeyMap(document, {
- key: Ext.EventObject.ENTER,
- fn: handleKey,
- scope: <b>this</b>
- });
- <i>//Add a <b>new</b> binding to the existing KeyMap later</i>
- map.addBinding({
- key: <em>'abc'</em>,
- shift: true,
- fn: handleKey,
- scope: <b>this</b>
- });</code></pre> <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li><code>config</code> : Object/Array<div class="sub-desc">A single KeyMap config or an array of configs</div></li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code>void</code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- <tr class="method-row expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-disable"></a>
- <b>disable</b>() : void <div class="mdesc">
- <div class="short">Disable this KeyMap</div>
- <div class="long">
- Disable this KeyMap <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li>None.</li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code>void</code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- <tr class="method-row alt expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-enable"></a>
- <b>enable</b>() : void <div class="mdesc">
- <div class="short">Enables this KeyMap</div>
- <div class="long">
- Enables this KeyMap <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li>None.</li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code>void</code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- <tr class="method-row expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-isEnabled"></a>
- <b>isEnabled</b>() : Boolean <div class="mdesc">
- <div class="short">Returns true if this KeyMap is enabled</div>
- <div class="long">
- Returns true if this KeyMap is enabled <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li>None.</li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code>Boolean</code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- <tr class="method-row alt expandable">
- <td class="micon"><a class="exi" href="#expand"> </a></td>
- <td class="sig">
- <a id="Ext.KeyMap-on"></a>
- <b>on</b>( <code>Number/Array/Object key</code>, <code>Function fn</code>, <span class="optional" title="Optional">[<code>Object scope</code>]</span> ) : void <div class="mdesc">
- <div class="short">Shorthand for adding a single key listener</div>
- <div class="long">
- Shorthand for adding a single key listener <div class="mdetail-params">
- <strong>Parameters:</strong>
- <ul><li><code>key</code> : Number/Array/Object<div class="sub-desc">Either the numeric key code, array of key codes or an object with the
- following options:
- {key: (number or array), shift: (true/false), ctrl: (true/false), alt: (true/false)}</div></li><li><code>fn</code> : Function<div class="sub-desc">The function to call</div></li><li><code>scope</code> : Object<div class="sub-desc">(optional) The scope of the function</div></li> </ul>
- <strong>Returns:</strong>
- <ul>
- <li><code>void</code></li>
- </ul>
- </div>
- </div>
- </div>
- </td>
- <td class="msource">KeyMap</td>
- </tr>
- </table>
- <a id="Ext.KeyMap-events"></a>
- <h2>Public Events</h2>
- <div class="no-members">This class has no public events.</div>
- </div>
|