推荐设备MORE

网页在线编辑

网页在线编辑

公司新闻

怎么弄微信小程序_解决vue.js中settimeout遇到的问题

日期:2021-01-05
我要分享
解决vue.js中settimeout遇到的问题(时间参数短效果不稳定)       这篇文章主要介绍了解决vue.js中settimeout遇到的问题(时间参数短效果不稳定),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

先看效果图,这是弹窗效果,要求就是弹窗出现和消失时候不是很突兀,要有过渡效果。

首先看弹窗出现的实现思路,先加一个beforeActive类,再加一个active类。我们看审查元素,一开始display:none;

在beforeActive中display:block;只是background: transparent;然后在一定时间后再加上active类。问题就来了,在打开弹窗代码中,如下图,settimeout第二个参数小于60ms效果就会不稳定,有时候有过渡效果,有时候没有过渡效果。

// openbtn(){
// let _this=this;
// _this.show =true;
// _this.isbeforeActive=true;
// setTimeout(function(){
// _this.isactive=true;
// },60)
// },

想了很久也没明白,后来终于明白,原来是vue渲染是有生命周期的,本来是先渲染befeactive,再渲染active,如果间隔时间太短就一次拿出来渲染了,所以没有效果。

在退出弹框时候这个时间小于600ms就显得特快,200ms的退出时间显得比60ms的进入还要急促很多,是因为退出等动画执行完毕才可以,而一个动画的执行需要300多,所以要用600ms

close_class(){
 let _this=this;
 _this.isactive=false;
 setTimeout(function(){
 _this.isbeforeActive=false;
 _this.show =false;
 },600)
 },

以下是完整代码

 template 
 div 
 button @click="openbtn" 显示 /button 
 div v-show="show" 
 div v-bind: @click="cancel_all" 
 div @click.stop="stop" 
 div 选择您的身份
 div id="pop-sure" @click="decision_click" 确定 /div 
 div id="pop-cancel" @click="close_click" 取消 /div 
 /div 
 div 
 li shenfen-id="jsptpl-style" v-for="(option,index) in options" @click.stop="add_class(index)" v-bind: 
 div {{option.text}} /div 
 div {{option.value}} /div 
 div /div 
 /li 
 /ul 
 /div 
 /div 
 /div 
 /div 
 /div 
 /template 
 script 
 export default {
 name: 'app',
 data() {
 return {
 show: false,
 current:1,
 isbeforeActive:false,
 isactive:false,
 options: [
 {"text": "房东", "value": "房屋所有者,具备认证房本资质"},
 {"text": "转租", "value": "转让自己承租的房子"},
 {"text": "经纪人", "value": "房产中介,拥有专业的展示空间"},
 {"text": "职业房东", "value": "公寓经营者/多房源管理者"}
 mounted() {
 computed: {},
 methods: {
 add_class(index){
 this.current=index;
 stop(){
 openbtn(){
 let _this=this;
 _this.show =true;
 _this.isbeforeActive=true;
 setTimeout(function(){
 _this.isactive=true;
 },60)
 close_class(){
 let _this=this;
 _this.isactive=false;
 setTimeout(function(){
 _this.isbeforeActive=false;
 _this.show =false;
 },600)
 decision_click(){
 this.close_class();
 close_click() {
 this.close_class();
 cancel_all(){
 this.close_class();
 watch: {},
 /script 
 style lang="scss" type="text/scss" 
 @import "../../../common/css/mixin";
 margin: 0px;
 padding: 0px;
 list-style: none

.shenfenPop-page .pop-title .pop-sure, .shenfenPop-page .pop-title .pop-cancel { position: absolute; z-index: 1; width: 1.6rem; height: 1.2rem; line-height: 1.22667rem; color: #ff552e; top: 0px; right: 0px; .shenfenPop-page .pop-title .pop-sure.pop-cancel, .shenfenPop-page .pop-title .pop-cancel.pop-cancel { right: auto; left: 0px; color: #7b7b7b; .shenfenPop-page .pop-list { widtH: 100%; .shenfenPop-page .pop-list ul { width: 9.33333rem; margin: 0 auto; .shenfenPop-page .pop-list ul li { width: 100%; height: 1.86667rem; position: relative; .shenfenPop-page .pop-list ul li:after { border-radius: 0px; content: ""; position: absolute; top: 0; left: 0; z-index: -1; border-bottom: 1px solid #f1f1f1; -webkit-box-sizing: border-box; box-sizing: border-box; width: 200%; height: 200%; -webkit-transform: scale(0.5); transform: scale(0.5); -webkit-transform-origin: left top; transform-origin: left top; .shenfenPop-page .pop-list ul li . { position: absolute; top: 0.4rem; font-size: 0.45333rem; color: #333333; left: 0.06667rem; .shenfenPop-page .pop-list ul li .pop-desc { font-size: 0.32rem; position: absolute; left: 0.06667rem; top: 0.98667rem; color: #7b7b7b; .shenfenPop-page .pop-list ul li .pop-arrow { position: absolute; right: 0.26667rem; width: 22px; height: 22px; top: 50%; margin-top: -11px; background-image: url(""); background-size: cover; .shenfenPop-page .pop-list ul li.active .pop-arrow { background-image: url("凡科抠图2jhZ9a8uijeZ/a2XVA897bdl8/cHyo4AfMtfHFz8Y+ZHLD/Ora4JfQPxq+//S5NfxLzPrWEC1LMpOAAAAAElFTkSuQmCC"); .shenfenPop-page.beforeActive { display: block; background: transparent; .shenfenPop-page.beforeActive .pop-wrap { transform: translateY(100%); .shenfenPop-page.active { /*background: rgba(0, 0, 0, 0.7);*/ .shenfenPop-page.active .pop-wrap { transform: translateY(0); /style

补充知识:setTimeout在vue中的正确使用

如下所示:

 mounted(){
 setTimeout(this.tishi(),5000) 
 },

这样写,发现直接就执行了tishi函数,而不是5s之后执行

修改为:

mounted(){
 let _this = this;
 setTimeout(() = {
 _this.tishi()
 },5000) 
 },

以上这篇解决vue.js中settimeout遇到的问题(时间参数短效果不稳定)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持凡科。