From 97a8442ba4ae7ec346b015facaf74973929cf448 Mon Sep 17 00:00:00 2001 From: shijian <2954700422@qq.com> Date: Wed, 27 Sep 2023 14:35:44 +0800 Subject: [PATCH] =?UTF-8?q?fix=20startScroll=20=3D=3D=20undfined,=E5=A2=9E?= =?UTF-8?q?=E5=8A=A0=E5=8E=9F=E5=9E=8B=E9=93=BE=E7=9A=84=E4=BB=A3=E7=A0=81?= =?UTF-8?q?=E6=8F=90=E7=A4=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- game/codemirror.js | 2 ++ game/game.js | 14 +++++++------- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/game/codemirror.js b/game/codemirror.js index 6114e137e..539b6d3be 100644 --- a/game/codemirror.js +++ b/game/codemirror.js @@ -10259,6 +10259,8 @@ } cm.on("scroll", this.onScroll = function () { + // fix "startScroll == undfined" + if (!startScroll) return; var curScroll = cm.getScrollInfo(), editor = cm.getWrapperElement().getBoundingClientRect(); var newTop = top + startScroll.top - curScroll.top; var point = newTop - (parentWindow.pageYOffset || (ownerDocument.documentElement || ownerDocument.body).scrollTop); diff --git a/game/game.js b/game/game.js index f6a6a37b9..b9ca1cec4 100644 --- a/game/game.js +++ b/game/game.js @@ -7506,8 +7506,7 @@ //覆盖原本的javascript提示 CodeMirror.registerHelper('hint','javascript',(editor,options)=>{ //Find the token at the cursor - let cur=editor.getCursor(), - token=editor.getTokenAt(cur); + let cur=editor.getCursor(),token=editor.getTokenAt(cur); if(/\b(?:string|comment)\b/.test(token.type)) return; const innerMode=CodeMirror.innerMode(editor.getMode(),token.state); if (innerMode.mode.helperType==="json") return; @@ -7523,10 +7522,9 @@ }; }else if(token.end>cur.ch){ token.end=cur.ch; - token.string=token.string.slice(0,cur.ch- oken.start); + token.string=token.string.slice(0,cur.ch-token.start); } - let tprop=token; - let context; + let tprop=token,context; //If it is a property, find out what it is a property of. while (tprop.type=="property"){ tprop=editor.getTokenAt(CodeMirror.Pos(cur.line,tprop.start)); @@ -7540,8 +7538,10 @@ try { const code=context.length==1?context[0].string:context.reduceRight((pre,cur)=>(pre.string||pre)+'.'+cur.string); const obj=eval(code); - const keys=Object.getOwnPropertyNames(obj).filter(key=>key.startsWith(token.string)); - list.addArray(keys); + if(![null,undefined].includes(obj)){ + const keys=Object.getOwnPropertyNames(obj).concat(Object.getOwnPropertyNames(Object.getPrototypeOf(obj))).filter(key=>key.startsWith(token.string)); + list.addArray(keys); + } }catch(_){ return;} }else if(token&&typeof token.string=='string'){ const javascriptKeywords=("break case catch class const continue debugger default delete do else export extends from false finally for function " +