aboutsummaryrefslogtreecommitdiff
path: root/contexts/data/lib/closure-library/closure/goog/demos/inputhandler.html
blob: 380d0d42a0dbb32aab4af243a970b3990261aaaa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<!DOCTYPE html>
<html>
<!--
Copyright 2010 The Closure Library Authors. All Rights Reserved.

Use of this source code is governed by the Apache License, Version 2.0.
See the COPYING file for details.
-->
<head>
<title>goog.events.InputHandler</title>
<script src="../base.js"></script>
<script>
goog.require('goog.dom');
goog.require('goog.events');
goog.require('goog.events.InputHandler');
</script>
<link rel="stylesheet" href="css/demo.css">
</head>
<body>
<h1>goog.events.InputHandler</h1>
<p><button onclick="addSome('text')">Add Some</button>
<input type=text id=text><span></span>


<p><button onclick="addSome('password')">Add Some</button>
<input type=password id=password><span></span>


<p><button onclick="addSome('textarea')">Add Some</button>
<textarea id=textarea></textarea><span></span>

<script>

var $ = goog.dom.getElement;

function addSome(id) {
  var el = $(id);
  el.value += '.';
}

function updateText(e) {
  var inputEl = e.target;
  var outputEl = inputEl.nextSibling;
  while (outputEl.hasChildNodes()) {
    outputEl.removeChild(outputEl.lastChild);
  }
  outputEl.appendChild(document.createTextNode(inputEl.value));
}

var textIh = new goog.events.InputHandler($('text'));
var passwordIh = new goog.events.InputHandler($('password'));
var textareaIh = new goog.events.InputHandler($('textarea'));

goog.events.listen(textIh, goog.events.InputHandler.EventType.INPUT,
                   updateText);
goog.events.listen(passwordIh, goog.events.InputHandler.EventType.INPUT,
                   updateText);
goog.events.listen(textareaIh, goog.events.InputHandler.EventType.INPUT,
                   updateText);

goog.events.listen(window, 'unload', function() {
  goog.events.unlisten(textIh, goog.events.InputHandler.EventType.INPUT,
                       updateText);
  goog.events.unlisten(passwordIh, goog.events.InputHandler.EventType.INPUT,
                       updateText);
  goog.events.unlisten(textareaIh, goog.events.InputHandler.EventType.INPUT,
                       updateText);
});

</script>
</body>
</html>