在Vue 组件Toast中如何实现显示框效果

这篇文章主要介绍了基于 flexiblevue 组件:toast显示框效果,需要的朋友可以参考下

基于flexible.js 的 Vue 组件

前言:

目前手头的移动端Vue项目是用手淘的 lib-flexible 作适配的,并用px2rem 来自动转换成rem。关于lib-flexible和px2rem的配置,请移步 vue-cli 配置 flexible 。

由于使用rem作适配,导致现有的很多移动端UI框架不能与之很好的配合,往往需要大动干戈更改UI框架的样式,背离了使用UI框架达到快速开发的初衷。

立即学习“前端免费学习笔记(深入)”;

为了以后项目的组件复用,以及提高开发可复用组件的能力,特把平时项目中 常用的、简单的 组件单独拎出来。

此为小白之作,论代码质量、难易程度、复用度,远不及各位大佬之杰作,求轻喷。同时,也恳请各位,提出意见和建议,不胜感激!

GitHub地址:vue-flexible-components

Toast — 显示框

效果展示

在Vue 组件Toast中如何实现显示框效果 

代码分析

p包含icon小图标和文字说明,构成简单的dom结构,利用props定义变量值,用computed计算属性对传入的值进行解构,watch监听弹框显示,并结合.sync修饰符达到双向数据绑定,同时用$emit向父组件派发事件,方便父组件监听回调。

dom结构

 

 

  

{{message}}

  

登录后复制

props数据

props: { message: { // 提示内容 type: String, }, toastShow: { // 是否显示 type: Boolean, default: false }, iconClass: { // 背景图片 type: String, }, iconImage: { // 自定义背景图片 }, duration: { // 定时器 type: Number, default: 1500 }, position: { // 弹出框位置 type: String, default: '50%' }},

登录后复制

computed

computed: { // 用于判断显示框位置 positionTop() { return { top: this.position } }, // 自定义父组件传过来的背景图片 iconBg() { if (this.iconImage) { return { backgroundImage: `url(${this.iconImage})` } } else { return; } }, // 用于判断icon是否显示 iconIsShow() { if (this.iconClass == 'success') { return true; } else if (this.iconClass == 'close') { return true; } else if (this.iconClass == 'warning') { return true; } else if (this.iconImage) { return true; } else { return false; } }},

登录后复制

watch

watch: { toastShow() { // 监听toast显示,向父组件派发事件 if (this.toastShow) { if (this.duration {  this.$emit('update:toastShow', false) // 利用了.sync达到双向数据绑定  this.$emit('toastClose'); }, this.duration) } } }}

登录后复制

使用说明

组件地址: src/components/Toast.vue (不能npm,只能手动下载使用)

下载并放入自己项目中 —— import 引入组件 —— components中注册组件 —— 使用

props

props 说明 类型 可选值 默认值

toastShow控制显示框显示、隐藏。需添加.sync修饰符才能自动关闭,详见例子Booleanfalse
     truefalsemessage提示信息StringiconClassicon小图标Stringsuccess
     warning
     closeiconImage自定义小图标(图片需require引入)duration定时器(毫秒),控制弹框显示时间,负数代表不执行定时任务Number1500position弹框位置(距顶)String’50%’

$emit

$emit 说明 参数

toastClose弹框关闭回调

示例

// 默认效果,只有提示信息   // 关于sync的说明,请看官网(主要是为了达到双向数据绑定,子组件修改父组件状态)  // 增加自带小图标 // 自定义类型   data() { return { this.isShow5 : true, bg: require('../assets/logo.png'), // 图片必须用require进来 } }, isClose5() { setTimeout(()=>{ this.isShow5 = false; }, 2000) }

登录后复制

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

如何解决Router跨模块跳转问题

如何解决Router跨模块跳转问题

如何解决Router跨模块跳转问题

如何解决Router跨模块跳转问题

如何解决Router跨模块跳转问题

以上就是在Vue 组件Toast中如何实现显示框效果的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3184306.html

(0)
上一篇 2025年3月31日 21:41:45
下一篇 2025年3月10日 19:24:53

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vue-cli+webpack无法新建项目

    这次给大家带来vue-cli+webpack无法新建项目,处理vue-cli+webpack无法新建项目的注意事项有哪些,下面就是实战案例,一起来看一下。 今日使用 npm init webpack love 创建一个新项目,然后执行 np…

    编程技术 2025年3月31日
    100
  • 在Vue中如何实现进入/离开动画

    这篇文章主要介绍了vue 进入/离开动画效果,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友可以参考下 1、示例代码 (注:写到vue单文件中了)             Toggle              hello      …

    2025年3月31日
    100
  • 使用vue实现简单键盘操作

    这篇文章主要介绍了使用vue实现简单键盘的示例(支持移动端和pc端),现在分享给大家,也给大家做个参考。 常看到各种app应用中使用自定义的键盘,本例子中使用vue2实现个简单的键盘,支持在移动端和PC端使用 实现效果: Keyboard.…

    2025年3月31日
    100
  • 在vue中如何实现分页组件

    本篇文章主要介绍了vue的一个分页组件的示例代码,现在分享给大家,也给大家做个参考。 分页组件在项目中经常要用到之前一直都是在网上找些jq的控件来用(逃..),最近几个项目用上vue了项目又刚好需要一个分页的功能。具体如下: 文件page.…

    编程技术 2025年3月31日
    100
  • 使用vue实现树形菜单栏功能

    这次给大家带来使用vue实现树形菜单栏功能,使用vue实现树形菜单栏功能的注意事项有哪些,下面就是实战案例,一起来看一下。 vue *{ color:#585858; } #app{ min-height: 650px; } #app li…

    编程技术 2025年3月31日
    100
  • VUE组件挂载方法详解

    这次给大家带来VUE组件挂载方法详解,VUE组件挂载的注意事项有哪些,下面就是实战案例,一起来看一下。 1、组件三种挂载方式 自动挂载 var app3 = new Vue({ el: ‘#app-3’, data: { seen: tru…

    编程技术 2025年3月31日
    100
  • vue做一个菜单

    这次给大家带来vue做一个菜单,vue做一个菜单的注意事项有哪些,下面就是实战案例,一起来看一下。 nbsp;html>          vue                 *{ color:#585858; } #app{ m…

    编程技术 2025年3月31日
    100
  • 在vue + element中如何实现表格分页

    众所周知element 是一套 vue.js 后台组件库,它能够帮助你更轻松更快速地开发后台项目。下面这篇文章主要给大家介绍了关于利用vue + element实现表格分页和前端搜索的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。 前…

    编程技术 2025年3月31日
    100
  • 在vue-cli中有关webpack3提速优化方面的问题

    这篇文章主要介绍了详解vue-cli之webpack3构建全面提速优化,现在分享给大家,也给大家做个参考。 前言 伴随着vue的全球化,已经各种vue的组件框架越来越完善,从早期的element-ui到vux,iview等越来越多高质量的项…

    编程技术 2025年3月31日
    100
  • 在Parcel.js + Vue 2.x中如何做到极速零配置打包

    这篇文章主要介绍了parcel.js + vue 2.x 极速零配置打包体验 的相关资料,需要的朋友可以参考下 继 Browserify、Webpack 之后,又一款打包工具 Parcel 横空出世 Parcel.js 的官网有这样的自我介…

    编程技术 2025年3月31日
    100

发表回复

登录后才能评论