Vue-loading根据主页img判断是否显示,以此解决vue首次加载白屏时间较长的尴尬

在vue项目中,文件打包后的在第一次访问时会出现较长的白屏等待时间,对于访问者来说非常不友好。

watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2xlbW9uX1RU,size_16,color_FFFFFF,t_70

除了数据压缩,结构优化外,最简单的应该就是在FP(First Paint)设置一个loading动画,来更好的过渡这段尴尬时间。

 

<template>

    <div id="fv_loading" v-show="showfv">

        <div class="fv_loadingBorder2"><div class="fv_loadingBorder3"><div class="fv_loadingBorder"></div></div></div>  

        <div class="fv_bounce">

                <span class="fv_letter"><br><br><br>C</span>

                <span class="fv_letter"><br><br><br>t</span>

                <span class="fv_letter"><br><br><br>r</span>

                <span class="fv_letter"><br><br><br>l</span>

                <span class="fv_letter"><br><br><br>C</span>

                <span class="fv_letter"><br><br><br>V</span>

                <span class="fv_letter"><br><br><br>e</span>

                <span class="fv_letter"><br><br><br>r</span>

        </div>

     </div>



  <div class="home" :style="getHomeHeight">

    <div class="home-hero-img" :class="{'home-hero-img-custom ': isHome}" id="home-hero-img">

      <img :src="getHeroImg" @load="swhcyx">

    </div>
  </div>

</template>

​ ​ fv_loading为首页加载代码块,设置v-show=“showfv”,默认为true,当进入页面时便会自动加载loding动画 ​ 给img标签加上load函数来控制showfv的值,这样当首页img加载完成后,执行load函数swhcyx(),将showfv的值置为false,loading动画display:none;主页也已经加载完毕。 ​

swhcyx(){

let _this = this
    _this.showfv= false

},

​
在mounted周期里面调用this.swhcyx()
​
 

 

 

首页加载loading,bgimg加载完成后loading ----display:none

在想要添加的界面中插入loading即可,或者注册为组件引用

在app.vue中引入则在所有界面中都有loading。

ps:不采用定时的方法是因为这样每次返回首页时就会加载loading,即使本地浏览器已经缓存网站。根据img是否load方法第一次加载图片会出现loading,此时浏览器已经缓存图片,再次进入首页几乎不会出现loading动画,有也是非常短。

这是我的解决方法,分享一下。可能解决不了你的问题但谢谢阅读!

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供关于使用vue-infinite-loading实现php无限的一些指导。 首先,您需要安装vue-infinite-loading。可以通过npm或yarn安装,具体操作为: ``` npm install vue-infinite-loading --save ``` 或 ``` yarn add vue-infinite-loading ``` 安装完成后,在您的Vue组件中引入该组件: ```javascript import InfiniteLoading from 'vue-infinite-loading'; export default { components: { InfiniteLoading, }, }; ``` 接下来,您需要在组件的template中使用该组件,并在data中定义需要的数据列表和当前页码: ```html <template> <div> <ul> <li v-for="item in list" :key="item.id">{{ item.title }}</li> </ul> <infinite-loading @infinite="infiniteHandler"></infinite-loading> </div> </template> <script> export default { data() { return { list: [], page: 1, }; }, methods: { infiniteHandler($state) { // 这里使用ajax请求获取数据,page为当前页码 axios.get('/api/list', { params: { page: this.page, }, }).then((res) => { if (res.data.length > 0) { this.list = this.list.concat(res.data); this.page += 1; $state.loaded(); } else { $state.complete(); } }); }, }, }; </script> ``` 在上面的代码中,我们使用axios发送ajax请求获取数据,并在请求成功后使用concat方法将新数据追到原数据列表中。同时,我们使用$state.loaded()方法告诉vue-infinite-loading组件数据已经完毕,可以继续下一页数据。如果返回的数据为空,则使用$state.complete()方法告诉vue-infinite-loading组件数据已经全部完毕。 最后,您需要在样式中设置vue-infinite-loading组件的高度和样式: ```css .vue-infinite-loading { height: 60px; line-height: 60px; text-align: center; } ``` 这样就完成了使用vue-infinite-loading实现php无限的操作。希望以上内容能够对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值