<p>
JS Function 'Animate' Fails in Chrome But Succeeds in IE: Resolving the Shadowing Issue
Problem Description
<p>An onClick event with an inline function named 'animate' designed to alter the style of an element fails in Chrome but functions as intended in IE. The code invoked within the 'animate' function aims to modify the element's position and color using JavaScript.
function animate() {
var div = document.getElementById('demo');
div.style.left = "200px";
div.style.color = "red";
}
Copy after login
#demo {
position: absolute;
}
Copy after login
Solution and Explanation
<p>The problem lies in JavaScript's scope chain and shadowing mechanism. When the inline event handler attribute (e.g., onclick) is utilized, the global function 'animate' becomes obscured by the recently introduced 'Element.prototype.animate' method, which stems from the Web Animations API.
window.animate // global function
Element.prototype.animate // element's own method
Copy after login
<p>According to the DOM specifications, the global event handler environment shadows the element's scope during event handling. Thus, the 'animate' method of the element takes precedence over the global 'animate' function.
10. Let the current event handler value be the result of the following steps:
...
4. Let the target environment be the lexical environment scope.
...
6. If the element is non-null, then
a. Let the target environment be the result of NewObjectEnvironment(the element, the target environment).
Copy after login
<p>To rectify this, one can employ several approaches:
- Rename the global function:
function animate__() {
var div = document.getElementById('demo');
div.style.left = "200px";
div.style.color = "red";
}
Copy after login
- Bind the global function to the target element:
document.getElementById('demo').addEventListener('click', animate.bind(document.getElementById('demo')));
Copy after login
The above is the detailed content of Why Does My `animate` Function Work in IE But Not Chrome: A JavaScript Shadowing Issue?. For more information, please follow other related articles on the PHP Chinese website!