Skip to content

v-show is firing late on 2.5.1 #6813

@ericcirone

Description

@ericcirone

Version

2.5.1

Reproduction link

https://codepen.io/ericcirone/pen/pWOrMB

Steps to reproduce

Go here - https://codepen.io/ericcirone/pen/pWOrMB
This is on 2.5.1 At < 1000px wide the test list should get hidden. If you go back and forth over that threshold you can make the list flash. It flashes because it is hidden by v-show. But in the CSS i make the list vertical under 1000px. It seems that v-show is firing a too late.

You can see the comparison to 2.4.4 here https://codepen.io/ericcirone/pen/Oxoxzr
On 2.4.4 you can not get the list to flash at the larger size.

What is expected?

List should be hidden at < 1000px.

What is actually happening?

List flashes vertical for a split second before disappearing.


Just noticed this when updating to 2.5.1. Hopefully its a quick fix. I'm using this behavior on a menu bar and now when you make the screen smaller its very janky.

Activity

ericcirone

ericcirone commented on Oct 13, 2017

@ericcirone
Author

Here is a video of the issue, just to further show it.

https://youtu.be/9BRqQa2Q9a4

doits

doits commented on Oct 14, 2017

@doits

You can see the comparison to 2.4.4 here https://codepen.io/ericcirone/pen/Oxoxzr
On 2.4.4 you can not get the list to flash at the larger size.

It flashes here for me, too, even with 2.4.4. (Firefox 57.0b8)

fritx

fritx commented on Oct 15, 2017

@fritx
doits

doits commented on Oct 15, 2017

@doits

@fritx 2.5.2 still flashes for me on resizing: https://codepen.io/anon/pen/PJyOJM

cannap

cannap commented on Oct 16, 2017

@cannap

i can also see on IE Edge

ericcirone

ericcirone commented on Oct 16, 2017

@ericcirone
Author

The issue definitely seems to be fixed in Chrome, but I do still see the issue in Safari and Firefox. Also I can see the issue in Safari and Firefox on 2.4.4 as well.

@yyx990803 So for situations like this, where I have CSS changing the appearance and Vue changing the appearance and wanting both to work exactly at the same moment, is it safe to say it should just all be done in CSS or all be done in Vue to make sure things are changed exactly at the same time?

added a commit that references this issue on Dec 15, 2017
04e68d3
added a commit that references this issue on Jan 25, 2019
11c527b
added a commit that references this issue on Mar 22, 2024
4e0c485
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

      Development

      No branches or pull requests

        Participants

        @doits@cannap@fritx@ericcirone

        Issue actions

          v-show is firing late on 2.5.1 · Issue #6813 · vuejs/vue