First, we need to understand how objects listen for property changes. Vue is implemented mainly by hijacking registered data through object.defineProperties and setting their set and GET methods in combination with the observer mode. Then the observer can be triggered in the set method. For specific implementation, you can see this article: vue.js bidirectional binding implementation principle. Now let’s look at arrays.
The array in JS is actually an object, and its data structure is exactly the same as the key-value pair structure of the object, but it simulates the data structure of the array for traversal, so it can obtain the stored data in order, for example, the array a[1] is actually converted into a[‘1’] for data preservation. As you traverse, you have to sort the properties to get the ordered data. And array objects provide many property-related operations, such as splite, slice, and so on. For details, see this: js array details.
A [1]=’a’. This is a flaw in data hijacking. A dynamically added property can only be registered by manually calling vue. set. In order to implement the array property listener, the vue. set method has to be constantly called. In order to implement the array property listener, we have to manually implement.
The function of the array is to constantly add and delete data, which has to constantly call the set method, which is bound to be more than the cost of return, so the array can realize the monitoring of properties, but the demand for monitoring is not strong and the cost is too high, so the array only needs to monitor the number of changes in its properties.
And how to listen is just to override the methods associated with this array object. These methods are methods that affect the number of properties of the array itself, also known as mutating methods. For detailed implementation, see this article: How to Listen for changes in an array.