Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
<meta name="description" content="Freeze panes with CSS and a bit of JavaScript">
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>JS Bin</title>
</head>
<body>
  <div class="container">
    <table>
      <thead>
        <tr>
          <th></th>
          <th>A</th>
          <th>B</th>
          <th>C</th>
          <th>D</th>
          <th>E</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <th>Hello</th>
          <td>1234</td>
          <td>34223</td>
          <td>flkajsdf</td>
          <td>single line</td>
          <td>flkajsdf</td>
        </tr>
        <tr>
          <th>Ni hao</th>
          <td>1234</td>
          <td>Foo bar baz foo bar baz</td>
          <td>some long words come in</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
        </tr>
        <tr>
          <th>Ciao</th>
          <td>1234</td>
          <td>34223</td>
          <td>Yes, multiple lines</td>
          <td>flkajsdf</td>
          <td>Welcome, multiple lines!</td>
        </tr>
        <tr>
          <th>Hello</th>
          <td>1234</td>
          <td>34223</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
        </tr>
        <tr>
          <th>Hello</th>
          <td>1234</td>
          <td>34223</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
        </tr>
        <tr>
          <th>Hello</th>
          <td>1234</td>
          <td>34223</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
        </tr>
        <tr>
          <th>Hello</th>
          <td>1234</td>
          <td>34223</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
          <td>flkajsdf</td>
        </tr>
      </tbody>
    </table>
  </div>
</body>
</html>
 
(function () {
  'use strict';
  var container = document.querySelector('.container');
  var table = document.querySelector('table');
  var leftHeaders = [].concat.apply([], document.querySelectorAll('tbody th'));
  var topHeaders = [].concat.apply([], document.querySelectorAll('thead th'));
  var topLeft = document.createElement('div');
  var computed = window.getComputedStyle(topHeaders[0]);
  container.appendChild(topLeft);
  topLeft.classList.add('top-left');
  topLeft.style.width = computed.width;
  topLeft.style.height = computed.height;
  container.addEventListener('scroll', function (e) {
    var x = container.scrollLeft;
    var y = container.scrollTop;
    leftHeaders.forEach(function (leftHeader) {
      leftHeader.style.transform = translate(x, 0);
    });
    topHeaders.forEach(function (topHeader, i) {
      if (i === 0) {
        topHeader.style.transform = translate(x, y);
      } else {
        topHeader.style.transform = translate(0, y);
      }
    });
    topLeft.style.transform = translate(x, y);
  });
  function translate(x, y) {
    return 'translate(' + x + 'px, ' + y + 'px)';
  }
})();
Output

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
shuheipro
0viewers