Ambiguity of JavaScript plus sign ' '_javascript skills
A single plus sign has three functions as an operator in JavaScript. It can represent string concatenation, for example:
var str = 'hello ' 'world!';
or a unary operator that represents a positive value of a number, for example:
var n = 10;
var n2 = n;
or represents the summation operation of numerical expressions, for example:
var n = 100;
var nn2 = n 1;
Among the three representations, string concatenation and numerical summation are prone to ambiguity. Because the processing of these two operations in JavaScript will depend on the data type, it cannot be judged from the operator. Let’s look at an expression alone:
aa = a b;
has no way of knowing whether its true meaning is summing or string concatenation. This is also impossible to determine when the JavaScript engine performs syntax analysis.
The main problem raised by the plus sign " " relates to another rule. This rule is "If there are strings in the expression, string concatenation is preferred." For example:
var v1 = '123';
var v2 = 456;
//Display the result value as the string '123456'
alert( v1 v2);
This will occur in some hosts Something went wrong. For example, in browsers, many values in the DOM model appear to be numbers, but are actually strings. So trying to do the "and" operation turned into a "string concatenation" operation. The following example illustrates this problem:
We see that the IMG element with the id testPic has a border with a width of 1 - the default unit px (pixel, pixel point) is omitted. But if you try to widen its borders with the following code, it will cause an error (some browsers ignore the value, others will pop up exceptions, and some browsers may crash):
var el = document.getElementById('testPic');
el.style. borderWidth = 10;
Because in fact in the DOM model, borderWidth is a united string value, so the value here will be "1px". JavaScript itself does not make errors, it will complete operations similar to the following and assign the value to borderWidth:
el.style.borderWidth = '1px' 10;
//The value is '1px10'
At this time, the browser's DOM model cannot interpret the meaning of "1px10", so an error occurs. When you read the borderWidth value again, it will still be the value 1px. So, how to prove the above operation process? The following code will show that the result of the JavaScript operation is 1px10, but when assigned to borderWidth, the DOM ignores this wrong value, so borderWidth is not actually modified:
alert( el.style.borderWidth = '1px' 10 );//The value is '1px10'
The root cause of this problem is that on the one hand we allow the writing of style sheets that omit units, and on the other hand the script engine cannot determine whether the operation here is a numerical operation or a string concatenation based on the operator.
Later, W3C promoted the XHTML specification and tried to avoid this problem from the first aspect, but the impact on the development community was still limited. Therefore, in the manuals provided by browser developers, the data type of each attribute will be stated as much as possible to prevent developers from writing code like the above. In this case, the most correct way to write it is:
var el = document.getElementById('testPic');
// 1. Get the original unit
var value = parseInt(el.style.borderWidth);
var unit = el.style.borderWidth .substr(value.toString().length);
// 2. Calculate the result and attach the unit
el.style.borderWidth = value 10 unit;
//If you know the attribute Using the default unit px and trying to still omit the unit value,
// Then you can use the following method (I do not recommend this):
// el.style.borderWidth = parseInt(el.style .borderWidth) 10;

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How to use WebSocket and JavaScript to implement an online speech recognition system Introduction: With the continuous development of technology, speech recognition technology has become an important part of the field of artificial intelligence. The online speech recognition system based on WebSocket and JavaScript has the characteristics of low latency, real-time and cross-platform, and has become a widely used solution. This article will introduce how to use WebSocket and JavaScript to implement an online speech recognition system.

WebSocket and JavaScript: Key technologies for realizing real-time monitoring systems Introduction: With the rapid development of Internet technology, real-time monitoring systems have been widely used in various fields. One of the key technologies to achieve real-time monitoring is the combination of WebSocket and JavaScript. This article will introduce the application of WebSocket and JavaScript in real-time monitoring systems, give code examples, and explain their implementation principles in detail. 1. WebSocket technology

How to use WebSocket and JavaScript to implement an online reservation system. In today's digital era, more and more businesses and services need to provide online reservation functions. It is crucial to implement an efficient and real-time online reservation system. This article will introduce how to use WebSocket and JavaScript to implement an online reservation system, and provide specific code examples. 1. What is WebSocket? WebSocket is a full-duplex method on a single TCP connection.

Introduction to how to use JavaScript and WebSocket to implement a real-time online ordering system: With the popularity of the Internet and the advancement of technology, more and more restaurants have begun to provide online ordering services. In order to implement a real-time online ordering system, we can use JavaScript and WebSocket technology. WebSocket is a full-duplex communication protocol based on the TCP protocol, which can realize real-time two-way communication between the client and the server. In the real-time online ordering system, when the user selects dishes and places an order

JavaScript and WebSocket: Building an efficient real-time weather forecast system Introduction: Today, the accuracy of weather forecasts is of great significance to daily life and decision-making. As technology develops, we can provide more accurate and reliable weather forecasts by obtaining weather data in real time. In this article, we will learn how to use JavaScript and WebSocket technology to build an efficient real-time weather forecast system. This article will demonstrate the implementation process through specific code examples. We

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

Usage: In JavaScript, the insertBefore() method is used to insert a new node in the DOM tree. This method requires two parameters: the new node to be inserted and the reference node (that is, the node where the new node will be inserted).

Introduction to the method of obtaining HTTP status code in JavaScript: In front-end development, we often need to deal with the interaction with the back-end interface, and HTTP status code is a very important part of it. Understanding and obtaining HTTP status codes helps us better handle the data returned by the interface. This article will introduce how to use JavaScript to obtain HTTP status codes and provide specific code examples. 1. What is HTTP status code? HTTP status code means that when the browser initiates a request to the server, the service
