Detailed explanation of implicit calls in javascript
This time I will bring you a detailed explanation of the implicit call of javascript. What are the precautions for implicit call using javascript. The following is a practical case, let's take a look.
Preface
I don’t know if it is accurate to describe it as implicit calling. Its behavior is always hidden behind the scenes, and it shows its face from time to time. It doesn’t seem to have much effect, but it is still useful to understand it. Guaranteed to be of great use under your use.
The so-called implicit call simply means automatically calling some methods, and these methods can be modified externally like hooks, thereby changing the established behavior.
Below I will list some implicit calls that I have seen recently. The examples are just to the point. Welcome to add
DataType conversion toSting and valueOf
var obj = { a: 1, toString: function () { console.log('toString') return '2' }, valueOf: function () { console.log('valueOf') return 3 } } console.log(obj == '2'); //依次输出 'valueOf' false console.log(String(obj));//依次输出 'toString' '2'
var obj = { a: 1, toString: function () { console.log('toString') return '2' }, valueOf: function () { console.log('valueOf') return {} //修改为对象 } } console.log(obj == '2'); //依次输出 'valueOf' 'toString' true console.log(Number(obj));//依次输出 'valueOf' 'toString' 2
In the operation of the equality operator, the object will first call valueOf. If the returned value is an object, it will call toSting, except null, and then use the returned value for comparison. The first example is equivalent to 3 == '2' outputs false. In the second example, executing valueOf returns an object, and then executes toString. Finally, it is equivalent to '2' == '2' and outputs true. In the Number and String methods, Number will call valueOf first. , and then call toString, which is the opposite in the String method.
In addition to the above two examples, conversion of data types also exists in various other operations, such as numerical operations. When reference types are involved, the valueOf or toString method will be called. , as long as the object is an object, it will inherit these two methods. We can override these two methods to affect the behavior of data type conversion
handleEvent in DOM2 event
var eventObj = { a: 1, handleEvent: function (e) { console.log(this, e);//返回 eventObj 和 事件对象 alert(this.a) } } document.addEventListener('click', eventObj)
You read that right, the second parameter of addEventListener can be an object in addition to a function. After the event is triggered, the handleEvent method of the object will be executed. When the method is executed, this points to eventObj. You can bind the data you want to pass in. Defined On the eventObj object
JSON object toJSON
var Obj = { a: 10, toJSON: function () { return { a: 1, b: function () { }, c: NaN, d: -Infinity, e: Infinity, f: /\d/, g: new Error(), h: new Date(), i: undefined, } } } console.log(JSON.stringify(Obj)); //{"a":1,"c":null,"d":null,"e":null,"f":{},"g":{},"h":"2018-02-09T19:29:13.828Z"}
If the object passed in by the stringify method of JSON has a toJSON method, then the object executed by this method will Convert to the object returned after toJSON is executed. One thing to note is that if the following code
var Obj1 = { a: 10, toJSON: function () { console.log(this === Obj1);//true return this } } console.log(JSON.stringify(Obj1));//{"a":10}
var Obj2 = { a: 10, toJSON: function () { console.log(this === Obj2);//true return { a: this } } } console.log(JSON.stringify(Obj2));//报错 Maximum call stack size exceeded
according to the above statement, it is obvious that the error is what we expected, but when returning this directly, no error is reported at all, so why not You can make a bold guess that it internally compares the object returned by toJSON with the original object. If they are equal, the then
##promise object's then
var obj = { then: function (resolve, reject) { setTimeout(function () { resolve(1000); }, 1000) } } Promise.resolve(obj).then(function (data) { console.log(data);// 延迟1秒左右输出 1000 })is used directly when Promise When the .resolve method passes in an object, if a then method exists, the then method will be executed immediately, which is equivalent to putting the method into a new Promise. In addition to Promise.resolve having this behavior, Promise.all also has this behavior
var timePromise = function (time) { return new Promise(function (resolve) { setTimeout(function () { resolve(time); }, time) }) } var timePromise1 = timePromise(1000); var timePromise2 = timePromise(2000); var timePromise3 = timePromise(3000); Array.prototype.then = function (resolve) { setTimeout(function () { resolve(4000); }, 4000) } Promise.all([timePromise1, timePromise2, timePromise3]).then(function (time) { console.log(time);// 等待4秒左右输出 4000 })
Object attribute accessor get and set
var obj = { _age: 100, get age() { return this._age You can see that no matter what age is set, my age is 18 years old or below. When performing attribute access, actually It is to call the get set function corresponding to the object attribute. In addition to the above writing method, there is also the following writing method <p style="text-align: left;"></p><pre class="brush:php;toolbar:false"> var input = document.createElement('input'); var span = document.createElement('span'); document.body.appendChild(input); document.body.appendChild(span); var obj = { _age:'' } var obj = Object.defineProperty(obj, 'age', { get: function () { return this._age; }, set: function (value) { this._age = value; input.value = value; span.innerHTML = value; } }); input.onkeyup = function (e) { if (e.keyCode === 37 || e.keyCode === 39) { return; } obj.age = this.value }Now the value value of input and the innerHTML value of obj.age attribute value span are bound together
Iterator interface Symbol.iterator
var arr = [ 1, 2 , 3]; arr[Symbol.iterator] = function () { const self = this; let index = 0; return { next () { if(index I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the PHP Chinese website! <p></p>Recommended reading: <p></p><p>JS Add Element New Node<a href="http://www.php.cn/xiaochengxu-389052.html" target="_blank"></a><br></p><p>4 Ways to JS Loop Nodelist Dom List<a href="http://www.php.cn/xiaochengxu-389051.html" target="_blank"> </a><br></p><p style="text-align: left;">How to achieve the intermittent loop scrolling effect of JS text<a href="http://www.php.cn/xiaochengxu-389048.html" target="_blank"></a><br></p>
The above is the detailed content of Detailed explanation of implicit calls in javascript. For more information, please follow other related articles on the PHP Chinese website!

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

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

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.
