不到30行JS代码实现Excel表格的方法

  本文实例讲述了不到30行JS代码实现Excel表格的方法,可见jQuery并非不可替代。分享给大家供大家参考。具体分析如下:

  某国外程序员展示了一个由原生JS写成不依赖第三方库的,Excel表格应用,有以下特性:

  ① 由不足30行的原生JavaScript代码实现

  ② 不依赖第三方库

  ③ Excel风格的语义分析 (公式以 "=" 开头)

  ④ 支持任意表达式 (=A1+B2*C3)

  ⑤ 防止循环引用

  ⑥ 基于localStorage的自动本地持久化存储

  效果展示如下图所示:

不到30行JS代码实现Excel表格的方法

  代码分析:

  CSS略,HTML核心仅一行:

  

复制代码 代码如下:
<table></table>

  JavaScript代码如下:

  

复制代码 代码如下:
for (var i=0; i<6; i++) {

  var row = document.querySelector("table").insertRow(-1);

  for (var j=0; j<6; j++) {

  var letter = String.fromCharCode("A".charCodeAt(0)+j-1);

  row.insertCell(-1).innerHTML = i&&j ? "" : i||letter;

  }

  }

  var DATA={}, INPUTS=[].slice.call(document.querySelectorAll("input"));

  INPUTS.forEach(function(elm) {

  elm.onfocus = function(e) {

  e.target.value = localStorage[e.target.id] || "";

  };

  elm.onblur = function(e) {

  localStorage[e.target.id] = e.target.value;

  computeAll();

  };

  var getter = function() {

  var value = localStorage[elm.id] || "";

  if (value.charAt(0) == "=") {

  with (DATA) return eval(value.substring(1));

  } else { return isNaN(parseFloat(value)) ? value : parseFloat(value); }

  };

  Object.defineProperty(DATA, elm.id, {get:getter});

  Object.defineProperty(DATA, elm.id.toLowerCase(), {get:getter});

  });

  (window.computeAll = function() {

  INPUTS.forEach(function(elm) { try { elm.value = DATA[elm.id]; } catch(e) {} });

  })();

  其实通过上文我们可以看出最核心的几步使用了EMEAScript5和HTML5的特性, 如:

  querySelectorAll: 提供类似jQuery选择器的查询,由此可见,第三方JS库如jQuery并不是必不少的。

  

复制代码 代码如下:
var matches = document.querySelectorAll("div.note, div.alert");

  defineProperty 提供了类以Java的get,set访问/设置预处理方法,还有其他一些配置属性,如:是否可配置,可枚举等。

  

复制代码 代码如下:
Object.defineProperty(o, "b", {get : function(){ return bValue; },

  set : function(newValue){ bValue = newValue; },

  enumerable : true,

  configurable : true});

  希望本文所述对大家的javascript程序设计有所帮助。