(2) Click the refresh button in the upper right corner, and tableView will reload and display a batch of new data.
(3) For the convenience of demonstration, every time the collected data is untrue, a network request is initiated. Instead, it is delayed for 2 seconds after local generation to simulate this asynchronous request.
The function of (/kloc-0 1)flatplattest is that when the "Refresh" button is repeatedly clicked in a short time (the last request hasn't come back yet), the table will only receive and display the last request, although multiple requests will still be initiated. Avoid the phenomenon that tables are constantly refreshed.
(2) We also limit the sources. That is, throttle sets a threshold (for example, 1 sec). If there are multiple clicks in 1 sec, only the last time is taken, then naturally only one data request is sent.
In an actual project, we may need to interrupt an unfinished network request. For example, when switching pages or classifying, if the last request has not been completed, it should be cancelled. The following example shows how to implement this function.
Here we add a "stop" button on the basis of the previous example. When the request is initiated and the data has not returned (within 2 seconds), the receiving and processing of the results will be stopped after pressing this button, that is, the requested data will not be loaded and displayed in this form.
This function is simply implemented by the takeUntil operator. When the observable object in takeUntil sends a value, it will end the corresponding observable object.