92行JavaScript代码实现的类似Excel外观的UI
2023-09-14 09:03:56 时间
源代码:
<html>
<body onload = render();>
<style type="text/css">
li {
list-style: none;
}
li:before {
/*content: "✓ ";*/
content: "A";
}
input {
border: none;
width: 80px;
font-size: 14px;
padding: 2px;
}
input:hover {
background-color: #eee;
}
input:focus {
background-color: #ccf;
}
input:not(:focus) {
text-align: right;
}
table {
border-collapse: collapse;
}
td {
border: 1px solid #999;
padding: 0;
}
tr:first-child td, td:first-child {
background-color: #ccc;
padding: 1px 3px;
font-weight: bold;
text-align: center;
}
footer {
font-size: 80%;
}
</style>
<script>
var WIDTH = 10;
var HEIGHT = 5;
function render(){
for (var i=0; i< HEIGHT; i++) {
var row = document.querySelector("table").insertRow(-1);
for (var j=0; j < WIDTH; j++) {
var letter = String.fromCharCode("A".charCodeAt(0)+j-1);
row.insertCell(-1).innerHTML = i&&j ? "<input id='"+ letter+i +"'/>" : 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) {} });
})();
}
</script>
<table></table>
</body>
</html>
如图:
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
相关文章
- javascript 高级教程 视频_精通JavaScript
- 导出的Excel名字乱码_恢复的excel文件乱码
- 进销存excel_用Excel制作简单的进销存系统「建议收藏」
- excel宏 java,Microsoft Excel宏运行Java程序
- 【说站】javascript中Array.join()方法如何使用
- 【说站】Excel如何快速删除空行?WPS删除excel空白行
- excel导入mysql代码_EXCEL导入Mysql方法「建议收藏」
- 上手JavaScript基准测试
- 《JavaScript高级程序设计》读书笔记
- 数据快速导出Excel:从MySQL中快速获取数据(excel导出mysql)
- 导入Excel数据到Oracle数据库(将excel导入oracle数据库)
- 快速实现Excel数据导入MySQL的方法(excel数据导入mysql)
- javascript里的条件判断
- 在JavaScript中通过URL传递汉字的方法
- 解析arp病毒背后利用的Javascript技术附解密方法
- javascript表单的友好用户体现
- javascript导出数据到Excel(处理table中的元素)
- javascript客户端解决方案缓存提供程序
- javascript使用activex控件的代码
- Javascript生成json的函数代码(可以用php的json_decode解码)
- jQuery对象和Javascript对象之间转换的实例代码
- javascript实现秒杀,团购倒计时展示的记录分享
- javascript操作excel生成报表示例
- javascript自定义的addClass()方法
- javascript面向对象之this关键词用法分析