При попытке использовать дебютную версию обработчика события mousemove d3.event
- null
. Я хотел бы использовать объект d3.mouse
в этом обработанном обработчике, но d3.event
возвращает null и выдает ошибку. Как я могу иметь доступ к d3.event
в следующем коде:d3.event имеет нулевую внутреннюю часть функции деблокирования
// a simple debounce function
function debounce(func, wait, immediate) {
var timeout;
return function() {
var context = this, args = arguments;
var later = function() {
timeout = null;
if (!immediate) {
func.apply(context, args);
}
};
var callNow = immediate && !timeout;
clearTimeout(timeout);
timeout = setTimeout(later, wait);
if (callNow) {
func.apply(context, args);
}
};
}
// the function to handle the mouse move
function handleMousemove (context) {
var mouse = d3.mouse(context);
console.log(mouse);
}
// create a debounced version
var debouncedHandleMousemove = debounce(handleMousemove, 250);
// set up the svg elements and call the debounced version on the mousemove event
d3.select('body')
.append('svg')
.append('g')
.append('rect')
.attr('width', 200)
.attr('height', 200)
.on('mousemove', function() {
debouncedHandleMousemove(this);
});
jsfiddle, если вы заботитесь, чтобы увидеть его в действии. Попытка mousemoving над элементом rect
.
Отличный ответ! Это решило мою проблему, большое спасибо – Rustam