2017-09-11 85 views
-2

我想同時具有onclick和懸停功能,但如果你點擊某處然後懸停不應該工作,直到我點擊其他地方。我已經嘗試了很多,但我沒有找到任何工作代碼。請幫助懸停和onclick功能問題在jquery

canvas.addEventListener('mousedown', function(evt) { 
    }, false); 
canvas.onmousemove = function(evt) { 

}; 
+0

請向我們提供您已經嘗試 – entiendoNull

+0

我添加的代碼_something_。請檢查 –

+2

這不是jQuery或節點。 –

回答

0

那麼,我不太清楚你需要什麼以及你爲什麼需要它。但是,在你寫的這段簡短的代碼中,我看到了「canvas」,並且認爲「這是什麼,那可能很有趣!」。我之前對canvas元素沒有太多經驗,所以我意識到可能有更好的編寫代碼的方法。

但是,我希望我在下面的例子中寫的東西至少接近你要找的東西。否則,堅決改變和適應你喜歡的方式...當你這樣做時,試着去學習一些東西。

var Canvas = function() { 
 
    this.$canvas = $('canvas'); 
 
    this.$currPos = $('#currPos'); 
 
    this.$currClick = $('#currClick'); 
 
    this.$clickInfo = $('#clickInfo'); 
 
    
 
    this.canvsWidth = 150; 
 
    this.cavasHeight = 150; 
 
    this.ctx = ctx = this.$canvas[0].getContext('2d'); 
 
    this.rect = this.$canvas[0].getBoundingClientRect(); 
 
    this.squares = []; 
 
    this.sqm = 50; 
 
    
 
    this.tracker = 0; 
 
    this.latestHover = {}; 
 
    
 
    this._events(); 
 
    this._prepare(); 
 
}; 
 

 
Canvas.prototype._events = function() { 
 
    var self = this; 
 
    
 
    this.$canvas.on('mousemove', function(e) { 
 
    var posX = e.clientX - self.rect.left, 
 
     posY = e.clientY - self.rect.top, 
 
     newX = Math.floor(posX/self.sqm), 
 
     newY = Math.floor(posY/self.sqm); 
 
    
 
    if($.isEmptyObject(self.latestHover) || (self.latestHover.x !== newX || self.latestHover.y !== newY)) { 
 
     self.latestHover.x = newX; 
 
     self.latestHover.y = newY; 
 
     
 
    self.squares.map(function(k, v) { 
 
     let obj = self.squares[v]; 
 
     if(!obj.fixedBackground) obj.reverseBackgroundColor(); 
 
    }); 
 

 
     var square = self.findObject(newX, newY)[0]; 
 
     if(square) { 
 
     square.setBackgroundColor('#ff0000'); 
 
     
 
     self.$currPos.html(newX +'x'+ newY); 
 
     self._redraw(); 
 
     } 
 
     
 
    } 
 
    }); 
 
    
 
    this.$canvas.on('click', function() { 
 
    if(self.tracker === 2) { 
 
     return self._reset(); 
 
    } 
 
    
 
    if(!($.isEmptyObject(self.latestHover))) { 
 
     var x = self.latestHover.x, 
 
      y = self.latestHover.y; 
 
      
 
     var square = self.findObject(x, y)[0]; 
 
      square.setFixedBackground(); 
 
      
 
     self.$currClick.html(x +'x'+ y); 
 
     self.setTracker(); 
 
    } 
 
    }); 
 
    
 
}; 
 

 
Canvas.prototype._prepare = function() { 
 
    for(var row = 0; row < 3; row++) { 
 
    for(var col = 0; col < 3; col++) { 
 
     this.squares.push(new Square(row, col, this.ctx, this.sqm)); 
 
    } 
 
    } 
 
}; 
 

 
Canvas.prototype._redraw = function() { 
 
    var self = this; 
 
    
 
    this.ctx.clearRect(0, 0, this.canvasWidth, this.canvasHeight); 
 

 
    this.squares.filter(function(k, v) { 
 
    self.squares[v].draw(); 
 
    }); 
 
}; 
 

 
Canvas.prototype.setTracker = function() { 
 
    this.tracker++; 
 
    
 
    if(this.tracker === 2) this.$clickInfo.html('Click one more time to start over'); 
 
}; 
 

 
Canvas.prototype.findObject = function(x, y) { 
 
    var self = this; 
 
    
 
    return square = self.squares.filter(function(k, v) { 
 
     var obj = self.squares[v]; 
 
     if(obj.posX === x && obj.posY === y) return obj; 
 
    }); 
 
}; 
 

 
Canvas.prototype._reset = function() { 
 
    var self = this; 
 
    
 
    this.squares.map(function(k, v) { 
 
    let obj = self.squares[v]; 
 
     obj.reverseBackgroundColor(); 
 
     obj.unsetFixedBackground(); 
 
    }); 
 
    
 
    this.$currClick.html(''); 
 
    this.$clickInfo.html(''); 
 
    this.tracker = 0; 
 
    this._redraw(); 
 
}; 
 

 
var Square = function(x, y, ctx, sqm) { 
 
    this.ctx = ctx; 
 
    this.sqm = sqm; 
 
    this.posX = x; 
 
    this.posY = y; 
 
    this.background = '#fff'; 
 
    this.strokeThickness = 1; 
 
    this.fixedBackground = false; 
 

 
    this.draw(); 
 
}; 
 

 
Square.prototype.setBackgroundColor = function(color) { 
 
    return this.background = color; 
 
}; 
 

 
Square.prototype.reverseBackgroundColor = function() { 
 
    return this.background = '#fff'; 
 
}; 
 

 
Square.prototype.setFixedBackground = function() { 
 
    return this.fixedBackground = true; 
 
}; 
 

 
Square.prototype.unsetFixedBackground = function() { 
 
    return this.fixedBackground = false; 
 
}; 
 

 
Square.prototype.draw = function() { 
 
    this.ctx.fillStyle = this.background; 
 
    this.ctx.fillRect(this.posX * this.sqm, this.posY * this.sqm, this.sqm, this.sqm); 
 
    this.ctx.strokeRect(this.posX * this.sqm, this.posY * this.sqm, this.sqm, this.sqm); 
 
}; 
 

 
window.Canvas = new Canvas();
canvas { 
 
    border: 1px solid #ccc; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<canvas width="150" height="150"></canvas> 
 
<div> 
 
    Current position: <span id="currPos"></span> <br/> 
 
    Last click: <span id="currClick"></span> <span id="clickInfo"></span> 
 
</div>