v-if 和 v-show 的真实使用场景
我们可以回忆下日常工作中的真实场景,决定使用 v-if 和 v-show 的依据是什么呢?
其核心应该是:v-if 会导致 组件(dom)的重新渲染,但是 v-show 不会。
重新渲染就意味着:整个生命周期会重新执行。 当 v-if 为 false 时,整个组件是不存在的,而变为 true 之后,组件会重新执行所有的生命周期回调。假如我们在 created 这种生命周期钩子中执行了 接口请求 的方法,这就意味着 此时接口的请求才会触发 。如果接口触发会 依赖其他参数(如:props) 那么此时的请求时机会刚刚好。
而对于 v-show 而言,整个生命周期只会触发一次。 当 v-show 为 false 时,组件虽然看不到,但是 已经存在了。这也就意味着,假如我们在 created 这种生命周期钩子中执行了 接口请求 的方法, 此时接口已经请求了,如果接口请求中涉及到 点击之后才可以获取的参数(props),那么此时因为没有点击,所以你可能会得到一个错误。
该问题如何回答
所以,基于以上原因,这个问题大家可以这么说(以下回答仅供参考):
Vue 官方中对 v-if 和 v-show 的使用场景区分是:当需要频繁显示和隐藏的时候,那么需要使用 v-show 否则需要使用 v-if。
但是在实际的开发中我们是 无法分辨一个场景(Dialog)是否是频繁切换的。
所以说,在实际开发中,判断 v-if 和 v-show 的使用需要根据它们的特性来进行判断。
v-show 不会导致组件被销毁和渲染,但是 v-if 会导致组件被销毁和重新渲染。
也就是说:当使用 v-show 时,虽然用户看不到组件,但是当前组件的生命周期都已经执行了。如果在 created 中存在接口的调用,则【接口已经调用完成】。同时,当组件隐藏时,组件并不会销毁。相反:如果是 v-if 的每次点击时都会重新渲染组件,重新执行生命周期,隐藏则销毁组件。
所以说,判断 v-if 和 v-show 的使用条件应该是:当组件需要在指定时机创建,在指定时机销毁时,需要使用 v-if。而 当组件仅需要创建一次时,则可以使用 v-show。