用JavaScript代码实现Excel表格的办法

这篇文章主要先容了不到30行JS代码实现Excel表格的方法,实现方法简单明白,很是具有实用代价,可部份代替jQuery的功能,jQuery并不是不行替代。必要的网友可以参考下

具体剖析以下:

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

① 由不到30行的原生JavaScript代码实现
② 基于localStorage的自动外地持久化存储
③ 防止轮回援用
④ 支持肆意标明式 (=A1+B2*C3)
⑤ Excel气势的语义剖析 (公式以 "=" 开头)
⑥ 不依赖第三方库

效果展示如下图所示:

wKiom1bexiqTVZwSAAAlyo-tIb0024.png

代码剖析:

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 ? "" : iletter;
}
}
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代码实现Excel表格的全部代码了。