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


     

    不到30行JS代码实现的Excel表格,jQuery并非不可替代

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

    • 由不足30行的原生JavaScript代码实现
    • 不依赖第三方库
    • Excel风格的语义分析 (公式以 "=" 开头)
    • 支持任意表达式 (=A1+B2*C3)
    • 防止循环引用
    • 基于localStorage的自动本地持久化存储

      效果展示:

      代码分析:

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

      原文 jsfiddle.net

  • 相关阅读:
    桃李春风一杯酒,江湖夜雨十年灯
    实现.net下的动态代理(续)多对象Mixin
    队列不存在,或您没有足够的权限执行该操作另一种原因
    .NET托管内存类应用的内存泄漏分析和诊断(转)
    移动硬盘 执行页内操作时的错误修复方法
    阮一峰:四位计算机的原理及其实现
    一款mvvm框架运用介绍(转)
    C#制作CAB压缩包压缩解压类
    ASP.NET C# 向 ACCESS 插入日期型数据 标准表达式中数据类型不匹配
    SQL Server日志清除的两种方法
  • 原文地址:https://www.cnblogs.com/macliu/p/3608663.html
Copyright © 2020-2023  润新知