【微信小程序】自定义showToast

文章介绍了在wx小程序中遇到showToast默认显示字数限制的问题,提供了一个解决方案,即创建一个自定义的toast组件来显示更多内容。该组件包含一个定时器,可在3秒后自动消失,并展示了如何在父组件中引入和使用这个自定义组件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对于wx小程序自己提供的showToast,当遇到提示的信息字数较多时,小程序中showToast默认只能显示7个字体长度,因此多余的字数会隐藏,所以我们就自己定义一个弹出框解决这个问题。

toast组件:

<template>
  <view class="container" v-if="Flag">
    <view class="content">
      {{ content }}
    </view>
  </view>
</template>

<script>
 //定时器标识timer
var timer = null;
export default {
  name: "mytoast",
  data() {
    return {
      Flag: false,
      content: "",
    };
  },
  methods: {
    showtoast(val) {
      this.content = val;
      // 每次清除上一次timer,若无也没影响
      clearTimeout(timer);
      this.Flag = true;
       // 添加定时器,3秒后消失
      timer = setTimeout(() => {
        this.Flag = false;
      }, 3000);
    },
  },
};
</script>

<style scoped>
.container {
  color: #ffffff;
  padding: 20rpx 20rpx;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 4px;
  position: absolute;
  left: 50%;
  top: 75%;
  transform: translate(-50%, -50%);
}

.content {
  text-align: center;
  font-size: 28rpx;
  width: 100%;
  height: 100%;
}
</style>

如何使用:

在父组件中需要使用组件的地方加入:

使用:<toast ref="mytoast"></toast>

引入:import toast from "./toast";

注册:components: { toast },

btnClick() {
	  // 绑定toast组件,调用toast组件内的方法
	  this.$refs.mytoast.showtoast( '成功' )
   }

效果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值