Merge pull request #164 from nonameShijian/PR-Branch
修复for in循环出现game.js定义的数组原型,增加includes的polyfill,修复layout.css的一个无意义大括号,修复game.print
This commit is contained in:
commit
0a8d2a9b8d
292
game/game.js
292
game/game.js
|
@ -7232,109 +7232,198 @@
|
||||||
return this.childNodes[row].childNodes[col];
|
return this.childNodes[row].childNodes[col];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
Array.prototype.filterInD=function(pos){
|
Object.defineProperty(Array.prototype, "filterInD", {
|
||||||
if(!pos) pos='o';
|
configurable:true,
|
||||||
var list=[];
|
enumerable:false,
|
||||||
for(var i=0;i<this.length;i++){
|
writable:true,
|
||||||
if(pos.indexOf(get.position(this[i],true))!=-1) list.push(this[i]);
|
value:function(pos){
|
||||||
|
if(!pos) pos='o';
|
||||||
|
var list=[];
|
||||||
|
for(var i=0;i<this.length;i++){
|
||||||
|
if(pos.indexOf(get.position(this[i],true))!=-1) list.push(this[i]);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
}
|
}
|
||||||
return list;
|
});
|
||||||
};
|
Object.defineProperty(Array.prototype, "contains", {
|
||||||
Array.prototype.contains=function(item){
|
configurable:true,
|
||||||
return this.indexOf(item)!=-1;
|
enumerable:false,
|
||||||
};
|
writable:true,
|
||||||
Array.prototype.add=function(){
|
value:function(item){
|
||||||
for(var i=0;i<arguments.length;i++){
|
return this.indexOf(item)!=-1;
|
||||||
if(this.contains(arguments[i])){
|
}
|
||||||
|
});
|
||||||
|
Object.defineProperty(Array.prototype, "add", {
|
||||||
|
configurable:true,
|
||||||
|
enumerable:false,
|
||||||
|
writable:true,
|
||||||
|
value:function(){
|
||||||
|
for(var i=0;i<arguments.length;i++){
|
||||||
|
if(this.contains(arguments[i])){
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
this.push(arguments[i]);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
Object.defineProperty(Array.prototype, "addArray", {
|
||||||
|
configurable:true,
|
||||||
|
enumerable:false,
|
||||||
|
writable:true,
|
||||||
|
value:function(arr){
|
||||||
|
for(var i=0;i<arr.length;i++){
|
||||||
|
this.add(arr[i]);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
Object.defineProperty(Array.prototype, "remove", {
|
||||||
|
configurable:true,
|
||||||
|
enumerable:false,
|
||||||
|
writable:true,
|
||||||
|
value:function(item){
|
||||||
|
if(Array.isArray(item)){
|
||||||
|
for(var i=0;i<item.length;i++) this.remove(item[i]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var pos=this.indexOf(item);
|
||||||
|
if(pos==-1){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
this.push(arguments[i]);
|
this.splice(pos,1);
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
return this;
|
});
|
||||||
};
|
Object.defineProperty(Array.prototype, "removeArray", {
|
||||||
Array.prototype.addArray=function(arr){
|
configurable:true,
|
||||||
for(var i=0;i<arr.length;i++){
|
enumerable:false,
|
||||||
this.add(arr[i]);
|
writable:true,
|
||||||
|
value:function(arr){
|
||||||
|
for(var i=0;i<arr.length;i++){
|
||||||
|
this.remove(arr[i]);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
return this;
|
});
|
||||||
};
|
Object.defineProperty(Array.prototype, "randomGet", {
|
||||||
Array.prototype.remove=function(item){
|
configurable:true,
|
||||||
if(Array.isArray(item)){
|
enumerable:false,
|
||||||
for(var i=0;i<item.length;i++) this.remove(item[i]);
|
writable:true,
|
||||||
return;
|
value:function(){
|
||||||
|
var arr=this.slice(0);
|
||||||
|
for(var i=0;i<arguments.length;i++) arr.remove(arguments[i]);
|
||||||
|
return arr[Math.floor(Math.random()*arr.length)];
|
||||||
}
|
}
|
||||||
var pos=this.indexOf(item);
|
});
|
||||||
if(pos==-1){
|
Object.defineProperty(Array.prototype, "randomRemove", {
|
||||||
return false;
|
configurable:true,
|
||||||
|
enumerable:false,
|
||||||
|
writable:true,
|
||||||
|
value:function(num){
|
||||||
|
if(typeof num=='number'){
|
||||||
|
var list=[];
|
||||||
|
for(var i=0;i<num;i++){
|
||||||
|
if(this.length){
|
||||||
|
list.push(this.randomRemove());
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
return this.splice(Math.floor(Math.random()*this.length),1)[0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
this.splice(pos,1);
|
});
|
||||||
return this;
|
Object.defineProperty(Array.prototype, "randomSort", {
|
||||||
};
|
configurable:true,
|
||||||
Array.prototype.removeArray=function(arr){
|
enumerable:false,
|
||||||
for(var i=0;i<arr.length;i++){
|
writable:true,
|
||||||
this.remove(arr[i]);
|
value:function(){
|
||||||
|
var list=[];
|
||||||
|
while(this.length){
|
||||||
|
list.push(this.randomRemove());
|
||||||
|
}
|
||||||
|
for(var i=0;i<list.length;i++){
|
||||||
|
this.push(list[i]);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
return this;
|
});
|
||||||
};
|
Object.defineProperty(Array.prototype, "randomGets", {
|
||||||
Array.prototype.randomGet=function(){
|
configurable:true,
|
||||||
var arr=this.slice(0);
|
enumerable:false,
|
||||||
for(var i=0;i<arguments.length;i++) arr.remove(arguments[i]);
|
writable:true,
|
||||||
return arr[Math.floor(Math.random()*arr.length)];
|
value:function(num){
|
||||||
};
|
if(num>this.length){
|
||||||
Array.prototype.randomRemove=function(num){
|
num=this.length;
|
||||||
if(typeof num=='number'){
|
}
|
||||||
|
var arr=this.slice(0);
|
||||||
var list=[];
|
var list=[];
|
||||||
for(var i=0;i<num;i++){
|
for(var i=0;i<num;i++){
|
||||||
if(this.length){
|
list.push(arr.splice(Math.floor(Math.random()*arr.length),1)[0]);
|
||||||
list.push(this.randomRemove());
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
else{
|
});
|
||||||
return this.splice(Math.floor(Math.random()*this.length),1)[0];
|
Object.defineProperty(Array.prototype, "sortBySeat", {
|
||||||
|
configurable:true,
|
||||||
|
enumerable:false,
|
||||||
|
writable:true,
|
||||||
|
value:function(target){
|
||||||
|
lib.tempSortSeat=target;
|
||||||
|
this.sort(lib.sort.seat);
|
||||||
|
delete lib.tempSortSeat;
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
};
|
});
|
||||||
Array.prototype.randomSort=function(){
|
if (!('includes' in Array.prototype)) {
|
||||||
var list=[];
|
Object.defineProperty(Array.prototype, 'includes', {
|
||||||
while(this.length){
|
enumerable: false,
|
||||||
list.push(this.randomRemove());
|
configurable: true,
|
||||||
}
|
writable: true,
|
||||||
for(var i=0;i<list.length;i++){
|
value: function (searchElement, fromIndex) {
|
||||||
this.push(list[i]);
|
if (this == null) {
|
||||||
}
|
throw new TypeError('"this" is null or not defined');
|
||||||
return this;
|
}
|
||||||
};
|
var o = Object(this);
|
||||||
Array.prototype.randomGets=function(num){
|
var len = o.length >>> 0;
|
||||||
if(num>this.length){
|
if (len === 0) {
|
||||||
num=this.length;
|
return false;
|
||||||
}
|
}
|
||||||
var arr=this.slice(0);
|
var n = fromIndex | 0;
|
||||||
var list=[];
|
var k = Math.max(n >= 0 ? n : len - Math.abs(n), 0);
|
||||||
for(var i=0;i<num;i++){
|
function sameValueZero(x, y) {
|
||||||
list.push(arr.splice(Math.floor(Math.random()*arr.length),1)[0]);
|
return x === y || (typeof x === 'number' && typeof y === 'number' && isNaN(x) && isNaN(y));
|
||||||
}
|
}
|
||||||
return list;
|
while (k < len) {
|
||||||
};
|
if (sameValueZero(o[k], searchElement)) {
|
||||||
Array.prototype.sortBySeat=function(target){
|
return true;
|
||||||
lib.tempSortSeat=target;
|
}
|
||||||
this.sort(lib.sort.seat);
|
k++;
|
||||||
delete lib.tempSortSeat;
|
}
|
||||||
return this;
|
return false;
|
||||||
};
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
if(!Array.from){
|
if(!Array.from){
|
||||||
Array.from=function(args){
|
Object.defineProperty(Array, "from", {
|
||||||
var list=[];
|
configurable:true,
|
||||||
if(args&&args.length){
|
enumerable:false,
|
||||||
for(var i=0;i<args.length;i++){
|
writable:true,
|
||||||
list.push(args[i]);
|
value:function(args){
|
||||||
|
var list=[];
|
||||||
|
if(args&&args.length){
|
||||||
|
for(var i=0;i<args.length;i++){
|
||||||
|
list.push(args[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return list;
|
||||||
}
|
}
|
||||||
return list;
|
});
|
||||||
}
|
|
||||||
}
|
}
|
||||||
window.onkeydown=function(e){
|
window.onkeydown=function(e){
|
||||||
if(!ui.menuContainer||!ui.menuContainer.classList.contains('hidden')){
|
if(!ui.menuContainer||!ui.menuContainer.classList.contains('hidden')){
|
||||||
|
@ -44825,6 +44914,7 @@
|
||||||
pre.style.margin=0;
|
pre.style.margin=0;
|
||||||
pre.style.padding=0;
|
pre.style.padding=0;
|
||||||
pre.style.position='relative';
|
pre.style.position='relative';
|
||||||
|
pre.style.webkitUserSelect = pre.style.userSelect = 'text';
|
||||||
lib.setScroll(pre);
|
lib.setScroll(pre);
|
||||||
page.appendChild(text);
|
page.appendChild(text);
|
||||||
|
|
||||||
|
@ -44921,26 +45011,28 @@
|
||||||
});
|
});
|
||||||
page.appendChild(text2);
|
page.appendChild(text2);
|
||||||
game.print=function(){
|
game.print=function(){
|
||||||
var textstr='';
|
var args=[].slice.call(arguments);
|
||||||
for(var i=0;i<arguments.length;i++){
|
var printResult=args.map(arg=>{
|
||||||
if(get.is.object(arguments[i])){
|
if(get.is.object(arg)){
|
||||||
var argi=get.stringify(arguments[i]);
|
var argi=get.stringify(arg);
|
||||||
if(argi&&argi.length<5000){
|
if(argi&&argi.length<5000){
|
||||||
textstr+=argi;
|
textstr+=argi;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
textstr+=arguments[i].toString();
|
textstr+=arg.toString();
|
||||||
}
|
}
|
||||||
|
}else{
|
||||||
|
var str=String(arg);
|
||||||
|
if (!/<[a-zA-Z]+[^>]*?\/?>.*?(?=<\/[a-zA-Z]+[^>]*?>|$)/.exec(str)) return String(arg)
|
||||||
|
.replace(/&/g, '&')
|
||||||
|
.replace(/</g, '<')
|
||||||
|
.replace(/>/g, '>')
|
||||||
|
.replace(/"/g, '"')
|
||||||
|
.replace(/'/g, ''');
|
||||||
|
else return str;
|
||||||
}
|
}
|
||||||
else{
|
}).join(' ');
|
||||||
textstr+=arguments[i];
|
pre.innerHTML+=printResult+'<br>';
|
||||||
}
|
|
||||||
if(i<arguments.length-1){
|
|
||||||
textstr+=' ';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
textstr+='<br>';
|
|
||||||
pre.innerHTML+=textstr;
|
|
||||||
text.scrollTop=text.scrollHeight;
|
text.scrollTop=text.scrollHeight;
|
||||||
}
|
}
|
||||||
if(_status.toprint){
|
if(_status.toprint){
|
||||||
|
|
|
@ -5374,4 +5374,3 @@ div[data-decoration="bronze"]::after{
|
||||||
::-webkit-scrollbar {
|
::-webkit-scrollbar {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
|
Loading…
Reference in New Issue