search
HomeWeb Front-endJS TutorialBrowser compatibility analysis of setTimeout and setInterval_Basic knowledge

When I accidentally tested the browser compatibility of AJAXRequest, I found that the AJAXRequest.update method had problems in IE in some cases. After testing, I found that the problem was setTimeout and setInterval.
The problem occurs when calling the AJAXRequest.update method. If the update interval and the number of updates are provided, then problems will occur under IE. The specific manifestation is that when the update interval is provided, the function works, and when the update number is provided, the function Unable to stop execution after the specified number of updates.
After testing several examples, I found the problem. In IE, setTimeout and setInterval do not support parameter passing.
Demo address: http://www.xujiwei.cn/demo/usetimer/
The syntax of setTimeout found in Netscape’s JavaScript reference is as follows:

Copy the code The code is as follows:

setTimeout
Evaluates an expression or calls a function once after a specified number of milliseconds elapses.
Syntax
setTimeout(expression, msec)
setTimeout(function, msec, arg1, ..., argN)
Parameters
expression A string containing a JavaScript expression.
msec A numeric value or numeric string, in millisecond units.
function Any function.
arg1, ..., argN (Optional) The arguments, if any, passed to function.

The second way to use it is to define A timer, when executing the function, will pass the parameters defined when calling setTimeout to the function. However, in IE, this method of calling is not supported, that is, when the function is executed, the function does not receive these parameters. parameter. For example:
Copy code The code is as follows:



In Firefox and Opera, the browser can correctly pop up the prompt box to display the string "my site: www.xujiwei.cn", while in IE, What is displayed is "my site: undefined", which means that the function show did not receive the parameter str, so it is displayed as an undefined variable.
Of course, if the variables used inside the function are global variables, there is no need to consider these issues, such as:
Copy code The code is as follows:



This code works normally in IE and Firefox, displaying "my site: www.xujiwei.cn".
When the variable is a global variable, you can use a statement segment to call setTimeout, that is, use the first syntax:
Copy code The code is as follows:



Because the variable url is a global variable, the statement segment "show(url);" defined by the timer execution can correctly pass parameters, but if url is not a global variable, When it is a local variable, the execution result will be wrong:
Copy the code The code is as follows:



An error will occur at this time. When the function test is executed, it will prompt that the url is undefined. When executing the defined statement segment "show (url);", the context has been separated from the function test, and the url is defined inside the function test, so when the function test is executed, the variable url has been released.
If you want to use local variables in setTimeout and solve the problem that setTimeout in IE does not support parameter passing, you can use an anonymous function, that is, define an anonymous function when calling setTimeout, and perform the original needs inside this function. operate.
Copy code The code is as follows:



In the above example, an anonymous function is defined when calling setTimeout, and its function body is "show(url);". Because the function has been defined, when the timer calls this function , the variable url is still referenced, because some functions can be executed correctly, and the string "my site: www.xujiwei.cn" is displayed.
In general, you need to pay attention to the following points when using setTimeout or setInterval:
1. If you use an expression when defining a timer, the variable in it should be a global variable or a direct value , and cannot be a local variable.
2. When defining a timer, if you define a calling function, you should only write the function name without adding parentheses. If you add it, you will define the return value.
3. Parameters cannot be passed when using timers in IE.
4. If you want to pass parameters when using a timer in IE, you can use an anonymous function and call the originally called function in the function body.

Please correct me if there are any errors.
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Javascript Data Types : Is there any difference between Browser and NodeJs?Javascript Data Types : Is there any difference between Browser and NodeJs?May 14, 2025 am 12:15 AM

JavaScript core data types are consistent in browsers and Node.js, but are handled differently from the extra types. 1) The global object is window in the browser and global in Node.js. 2) Node.js' unique Buffer object, used to process binary data. 3) There are also differences in performance and time processing, and the code needs to be adjusted according to the environment.

JavaScript Comments: A Guide to Using // and /* */JavaScript Comments: A Guide to Using // and /* */May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript: A Comparative Analysis for DevelopersPython vs. JavaScript: A Comparative Analysis for DevelopersMay 09, 2025 am 12:22 AM

The main difference between Python and JavaScript is the type system and application scenarios. 1. Python uses dynamic types, suitable for scientific computing and data analysis. 2. JavaScript adopts weak types and is widely used in front-end and full-stack development. The two have their own advantages in asynchronous programming and performance optimization, and should be decided according to project requirements when choosing.

Python vs. JavaScript: Choosing the Right Tool for the JobPython vs. JavaScript: Choosing the Right Tool for the JobMay 08, 2025 am 12:10 AM

Whether to choose Python or JavaScript depends on the project type: 1) Choose Python for data science and automation tasks; 2) Choose JavaScript for front-end and full-stack development. Python is favored for its powerful library in data processing and automation, while JavaScript is indispensable for its advantages in web interaction and full-stack development.

Python and JavaScript: Understanding the Strengths of EachPython and JavaScript: Understanding the Strengths of EachMay 06, 2025 am 12:15 AM

Python and JavaScript each have their own advantages, and the choice depends on project needs and personal preferences. 1. Python is easy to learn, with concise syntax, suitable for data science and back-end development, but has a slow execution speed. 2. JavaScript is everywhere in front-end development and has strong asynchronous programming capabilities. Node.js makes it suitable for full-stack development, but the syntax may be complex and error-prone.

JavaScript's Core: Is It Built on C or C  ?JavaScript's Core: Is It Built on C or C ?May 05, 2025 am 12:07 AM

JavaScriptisnotbuiltonCorC ;it'saninterpretedlanguagethatrunsonenginesoftenwritteninC .1)JavaScriptwasdesignedasalightweight,interpretedlanguageforwebbrowsers.2)EnginesevolvedfromsimpleinterpreterstoJITcompilers,typicallyinC ,improvingperformance.

JavaScript Applications: From Front-End to Back-EndJavaScript Applications: From Front-End to Back-EndMay 04, 2025 am 12:12 AM

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Python vs. JavaScript: Which Language Should You Learn?Python vs. JavaScript: Which Language Should You Learn?May 03, 2025 am 12:10 AM

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft