Requirement: When users enter this page, they can see the el-Badge on the el-Tab.
Problem: El-Badge binding variables have data, but the interface does not render.
Code:
< el-Tabs > < El-Tab-Pane > < SPAN slot="label"> < I class="el-icon-message"> Personal information </ I > < EL-Badge :value="todo" V-if ="todo>0" Size = "mini" class = "item" > < / el badge - > < / span > < / el - TAB - pane > < el - TAB - pane label = "user management" name = "user" > < / el - TAB - pane > </el-tabs> </template>Copy the code
<script>
export default {
data() {
return {
todo: 0,
}
},
mounted() {// delegate datagetTodo() {
this.$http({
method: "post", url: `... `, params: {... } }).then(res => { console.log("Agent data request successful", res.data.data.todoNum); this.todo = res.data.data.todoNum || 0; })}},created() {
}
}
</script>
Copy the code
It printed successfully in getTodo: agent data request success1
However, the view is as follows:
When you click on the TAB TAB, it shows:
After consulting relevant materials, I found the following statement on vUE’s official website:
Example: Force a Vue instance to re-render. Note that it affects only the instance itself and the children that insert slot content, not all children. Forced update If you find yourself needing a forced update in Vue, 99.9% of the time, you've done something wrong. You may not have noticed the change-detection considerations for arrays or objects, or you may be relying on a state that is not tracked by Vue's responsive system. However, if you have done all of the above and still find yourself needing to manually force updates in rare cases, you can do so with $forceUpdate. Solution:Copy the code
Add a sentence after the getTodo request to the data:
this.$children[0].$children[0].$forceUpdate();
Then when you open the page, the tag on the TAB appears: