您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
add sorting to tables
当前为
- // ==UserScript==
- // @name Jstris table sort
- // @namespace
- // @version 0.2
- // @description add sorting to tables
- // @author mxmossy
- // @match https://*.jstris.jezevec10.com/*
- // @icon 
- // @grant none
- // @license MIT
- // ==/UserScript==
- (function() {
- // adapted from https://stackoverflow.com/questions/14267781/sorting-html-table-with-javascript
- var getCellValue = function(tr, idx){ return tr.children[idx].innerText || tr.children[idx].textContent; }
- var format = function(s){return s.replace(/[:\- ]/g, "")}
- var comparer = function(idx, asc) {
- return function(a, b) {
- return function(v1, v2) {
- if(v1 !== '' && v2 !== '' && !isNaN(v1) && !isNaN(v2)){
- return v1 - v2;
- }
- else if(v1.includes(":") || v2.includes(":")){
- return parseFloat(format(v1)) - parseFloat(format(v2));
- }
- else return v1.toString().localeCompare(format(v2));
- }(getCellValue(asc ? a : b, idx), getCellValue(asc ? b : a, idx));
- }};
- // do the work...
- Array.prototype.slice.call(document.querySelectorAll('th')).forEach(function(th) { th.addEventListener('click', function() {
- var table = th.parentNode;
- while(table.tagName.toUpperCase() != 'TABLE') table = table.parentNode;
- var tableBody = table.querySelector('tbody');
- Array.prototype.slice.call(table.querySelectorAll('tbody tr:nth-child(n+1)'))
- .sort(comparer(Array.prototype.slice.call(th.parentNode.children).indexOf(th), this.asc = !this.asc))
- .forEach(function(tr) { tableBody.appendChild(tr) });
- })});
- })();