This time I will bring you how to prevent vue page loading from flickering, and what are the precautions on how to prevent vue page loading from flickering. The following is a practical case, let's take a look.
The difference between v-if and v-show
v-if will only compile when the conditions are met, while v-show It will always compile regardless of whether the conditions are met. The display and hiding of v-show is just a simple switch of the display attribute of CSS.
In other words, when using v-if, if the value is false, then the page will not have this html tag generated. And v-show: regardless of whether its value is false or true, the html element will exist, just simply switch the display attribute of the css.
Usage scenarios
Generally speaking, v-if has a higher switching cost and v-show has a higher initial rendering cost . Therefore, v-show is better if you need to switch frequently, and v-if is better if conditions are unlikely to change at runtime.
In addition
1. The v-if directive can be applied to the template packaging element, but v-show does not support template
2. When applying v-show to a component, there will be a problem because of the priority of the instruction v-else. The solution is to replace v-else with another v-show
1 2 3 4 5 6 |
|
Solution to {{message}} crash when loading vue page
Method 1: v-cloak
v-cloak command and When used together with css rules such as [v-cloak]{display:none}, this directive can hide uncompiled Mustache tags until the instance is ready.
The v-cloak directive can bind a set of css styles like a css selector, and then this set of css will take effect until the instance is compiled.
1 2 3 4 5 6 7 8 |
|
Method 2: v-text
In vue we will wrap the data in two curly brackets and then put it in HTML, but inside vue, All double brackets will be compiled into a v-text directive of textNode.
The advantage of using v-text is always better performance, and more importantly, it can avoid FOUC (Flash of Uncompiled Content), which is the problem encountered above.
1 2 3 4 |
|
Supplement:
vue page loading progress bar component
Page loading progress bar initially I saw it on YouTube, and it can be seen on almost all major websites later. It can prevent users from staring at a completely blank page when loading the page, and improve the user experience
But from a development perspective, it is really difficult to grasp the authenticity of this kind of progress bar, because we cannot count the progress until the logic code is loaded, and the progress of the logic code itself cannot be counted. In addition, it is impossible for us to monitor the loading of all resources.
In fact, users don’t care what percentage of your page is loaded, but what they really care about is how long it is until it is fully loaded, and whether the blank page has not been fully loaded or is blank after it is loaded. of. So we don't need to "simulate" a progress bar, use a fake animation effect to simulate loading before the back-end data is returned, and read the progress bar and hide it after the data is returned.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
|
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!
Recommended reading:
How to pass an array to the background controller
##Use JS to receive List
The above is the detailed content of How to prevent vue page loading from flickering. For more information, please follow other related articles on the PHP Chinese website!