chromium/third_party/google-closure-library/closure/goog/demos/inputhandler.html

<!DOCTYPE html>
<html>
<!--
Copyright 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.debug.DivConsole');
goog.require('goog.dom');
goog.require('goog.events');
goog.require('goog.events.InputHandler');
goog.require('goog.log');
</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>

<br><br>
<fieldset class="goog-debug-panel">
  <legend>Event Log</legend>
  <div id="log" style="height: 400px;"></div>
</fieldset>

<script>
var $ = goog.dom.getElement;
var logger = goog.log.getLogger('demo');
var logconsole = new goog.debug.DivConsole(goog.dom.getElement('log'));

goog.log.setLevel(goog.log.getRootLogger(), goog.log.Level.FINER);
logconsole.setCapturing(true);

var DOM_EVENTS = ['keydown', 'keyup', 'keypress', 'change', 'cut', 'paste',
    'drop', 'input'];
var INPUTHANDLER_EVENTS =
    goog.object.getValues(goog.events.InputHandler.EventType);


function logEvent(src, e) {
  goog.log.info(logger, '[Event from ' + src + ']:  ' + e.type);
}

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));
}


goog.object.forEach(['text', 'password', 'textarea'], function(id) {
  var el = $(id);
  var ih = new goog.events.InputHandler(el);

  goog.events.listen(ih, goog.events.InputHandler.EventType.INPUT, updateText);
  goog.events.listen(ih, INPUTHANDLER_EVENTS,
      goog.partial(logEvent, 'InputHandler'));
  goog.events.listen(el, DOM_EVENTS,
      goog.partial(logEvent, 'DOM'));
});
</script>
</body>
</html>