मैं DIV के साथ कर्सर का पालन करने के लिए jQuery का उपयोग कैसे कर सकता हूं?
जवाबों:
आप एक के साथ कर्सर का पालन नहीं कर सकते हैं DIV
, लेकिन आप DIV
कर्सर को स्थानांतरित करते समय आकर्षित कर सकते हैं !
$(document).on('mousemove', function(e){
$('#your_div_id').css({
left: e.pageX,
top: e.pageY
});
});
वह div फ्लोट से दूर होना चाहिए, इसलिए position: absolute
सेट किया जाना चाहिए।
इसके लिए आपको jQuery की आवश्यकता नहीं है। यहाँ एक सरल काम उदाहरण है:
<!DOCTYPE html>
<html>
<head>
<title>box-shadow-experiment</title>
<style type="text/css">
#box-shadow-div{
position: fixed;
width: 1px;
height: 1px;
border-radius: 100%;
background-color:black;
box-shadow: 0 0 10px 10px black;
top: 49%;
left: 48.85%;
}
</style>
<script type="text/javascript">
window.onload = function(){
var bsDiv = document.getElementById("box-shadow-div");
var x, y;
// On mousemove use event.clientX and event.clientY to set the location of the div to the location of the cursor:
window.addEventListener('mousemove', function(event){
x = event.clientX;
y = event.clientY;
if ( typeof x !== 'undefined' ){
bsDiv.style.left = x + "px";
bsDiv.style.top = y + "px";
}
}, false);
}
</script>
</head>
<body>
<div id="box-shadow-div"></div>
</body>
</html>
मैंने चुना है position: fixed;
इसलिए स्क्रॉल करना कोई समस्या नहीं होगी।
यह मेरे लिए काम करता है। एक अच्छा देरी कार्रवाई चल रही है।
var $mouseX = 0, $mouseY = 0;
var $xp = 0, $yp =0;
$(document).mousemove(function(e){
$mouseX = e.pageX;
$mouseY = e.pageY;
});
var $loop = setInterval(function(){
// change 12 to alter damping higher is slower
$xp += (($mouseX - $xp)/12);
$yp += (($mouseY - $yp)/12);
$("#moving_div").css({left:$xp +'px', top:$yp +'px'});
}, 30);
अच्छा और अनुकरण करता है
.css()
मेरे लिए काम करने के बजाय शुद्ध jQuery समाधान का उपयोग करना । फ़ंक्शन के अंदर, इस लाइन का उपयोग करें:$('#your_div_id').offset({left: e.page, top: e.pageY});