簡體   English   中英

Javascript僅在IE Quirks,7和Chrome和Firefox中有效。 在IE 8或9標准中不起作用

[英]Javascript only works in IE Quirks, 7 and Chrome and Firefox. Doesn't work in IE 8 or 9 Standards

我的代碼使許多划分似乎圍繞平面上不可見的水平軸旋轉。 工作原理:在onMouseDown上觸發mouseevent偵聽器,並捕獲用戶光標相對於窗口的X。 onMouseUp由setTimeout函數模擬,該函數在90毫秒后被調用,它執行相同的操作,然后將這兩個值相減以確定旋轉的距離和方向。

我的問題是:為什么它在FF,Chrome和IE Quirks和IE 7標准而不是IE 8標准或IE 9標准中正常工作?

IE8:模型崩潰,並且分度在包含邊界的分度之外浮動。 IE9:JS沒有任何響應。

以下內容包含頁面上的整個JavaScript,可以在@ http://electrifiedpulse.com/360.html上找到它們:

<script type=text/javascript>
var objectCount = 8; var pixel = new Array(); var size = new Array();
var command = "Stop"; var panel = new Array('0','Back','Front','Front','Back','Front','Back','Front','Back'); 
var quadrant = new Array(); var originalSize = 50;
var WindowWidth = 360; var WindowWidthHalf = WindowWidth/2; var sTime=0; var s1=0; var scrollSpeed;

var myX, myY;
function myMove(evt) {
  if (window.event){myX = event.clientX;myY = event.clientY;}
  else{myX = evt.clientX;myY = evt.clientY;}
}

document.onmousemove = myMove;
if (!window.event) {document.captureEvents(Event.MOUSEMOVE);}

function iScrollStop(){
sTime = sTime - 10; 
document.getElementById('I_CONTROLS').innerHTML = sTime + ", " + scrollSpeed;
if(sTime<=0) command = "Stop";
else setTimeout(function(){iScrollStop()},10);
}

function iScrollPause(){
setTimeout(function(){this.checkPause()},100);
this.checkPause = function(){if(s1>sTime){command="Stop"; sTime=0; s1=0;}}
}

var iInitialX; //var d='Up';
function iScrollListen(d){

if(d=='Down'){ iInitialX = myX; setTimeout(function(){iScrollListen('Up')},90); iScrollPause(); 
}else if(d=='Up'){
var spinDirection = 'Right';
var iDifference = myX - iInitialX; if(iDifference < 0){ spinDirection = 'Left'; iDifference = Math.abs(iDifference);}
if (command!=spinDirection){sTime=0;s1=0;} var doScroll=0; if(command=='Stop') doScroll=1;
command = spinDirection; s1=sTime; sTime+=(iDifference*15); if(s1<=0)iScrollStop(); 
if(doScroll==1) iScroll(); 

}
}

function iScrollControl(c){command = c; if((c=='Left')||(c=='Right')) iScroll();}

function iScroll(){
scrollSpeed=(sTime<=1)? 1 : Math.ceil(sTime/1000);
if(scrollSpeed>=10)scrollSpeed=10;
scrollSpeed = 15 - scrollSpeed;

if(command=='Left') pixelDirection=2;
else if(command=='Right') pixelDirection=(0-2);
pixelDirectionNeg = (0-pixelDirection);

for(i=1;i<=objectCount;i++){
iObj = document.getElementById("iObject" + i);
pixel[i] = iObj.offsetLeft;

if((pixel[i]>=WindowWidthHalf)&&(pixel[i]<=WindowWidth)){
if(panel[i]=="Front") quadrant[i] = 4;
else quadrant[i] = 3;
}
if((pixel[i]>=0)&&(pixel[i]<=WindowWidthHalf)){
if(panel[i]=="Front") quadrant[i] = 1;
else quadrant[i] = 2;
}




if(quadrant[i]==1){
iObj.style.left = pixel[i]-pixelDirection;
size[i] = (pixel[i]-pixelDirection)*(1/(WindowWidthHalf/(originalSize/2))) + (originalSize/2);
Attribute(iObj,size[i]);
if(pixel[i]-pixelDirection<=0){quadrant[i]=2; panel[i]='Back';}
if(pixel[i]-pixelDirection>=WindowWidthHalf){quadrant[i]=4; panel[i]='Front';}
}

if(quadrant[i]==2){
iObj.style.left = pixel[i]-pixelDirectionNeg;
size[i] = (pixel[i]-pixelDirectionNeg)*(-1/(WindowWidthHalf/(originalSize/2))) + (originalSize/2);
Attribute(iObj,size[i]);
if(pixel[i]-pixelDirectionNeg<=0){quadrant[i]=1; panel[i]='Front';}
if(pixel[i]-pixelDirectionNeg>=WindowWidthHalf){quadrant[i]=3; panel[i]='Back';}
}

if(quadrant[i]==3){
iObj.style.left = pixel[i]-pixelDirectionNeg;
size[i] = (WindowWidth-(pixel[i]-pixelDirectionNeg))*(-1/(WindowWidthHalf/(originalSize/2))) + (originalSize/2);
Attribute(iObj,size[i]);
if(pixel[i]-pixelDirectionNeg<=WindowWidthHalf){quadrant[i]=2; panel[i]='Back';}
if(pixel[i]-pixelDirectionNeg>=WindowWidth){quadrant[i]=4; panel[i]='Front';}
}

if(quadrant[i]==4){
iObj.style.left = pixel[i]-pixelDirection;
size[i] = (WindowWidth-(pixel[i]-pixelDirection))*(1/(WindowWidthHalf/(originalSize/2))) + (originalSize/2);
Attribute(iObj,size[i]);
if(pixel[i]-pixelDirection<=WindowWidthHalf){quadrant[i]=1; panel[i]='Front';}
if(pixel[i]-pixelDirection>=WindowWidth){quadrant[i]=3; panel[i]='Back';}
}

}


if((command=='Left')||(command=='Right')) setTimeout(function(){iScroll()},scrollSpeed);

}

function Attribute(iObj,s){
iObj.style.width = s; iObj.style.height = s; iObj.style.top='50%'; iObj.style.marginTop = (0-(s/2))+"px"; iObj.style.zIndex = s;
}

</script>

我不知道與您可能有什么關系,也可能與您無關。因此,我包括了整個腳本。 如果您想忽略最長的函數,

iScroll()

@RyanStortz。 嘗試在此方式中注冊事件:

var isMouseCaptured=false;
function i_boundary_mousedown(ev) {
    isMouseCaptured=true;
    iScrollListen("Down");
}
function doc_mousemove(ev) {
    if(isMouseCaptured) {
        ev=ev||event;
        myX=ev.clientX;
        myY=ev.clientY;
    }
}
function doc_mouseup(ev) {
    if(isMouseCaptured) {
        isMouseCaptured=false;
        ev=ev||event;
        myX=ev.clientX;
        myY=ev.clientY;
    }
}

var i_boundaryObj=document.getElementById('I_BOUNDARY');
if(window.addEventListener) {
    i_boundaryObj.addEventListener('mousedown',i_boundary_mousedown,false);
    document.addEventListener('mousemove',doc_mousemove,false);
    document.addEventListener('mouseup',doc_mouseup,false)
}
else if(window.attachEvent) {
    i_boundaryObj.attachEvent('onmousedown',i_boundary_mousedown)
    document.attachEvent('onmousemove',doc_mousemove);
    document.attachEvent('onmouseup',doc_mouseup)
}
else ;//

為具有類“ I_BOUNDARY”的id屬性“ I_BOUNDARY”的DIV添加,並刪除onmousedown屬性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM