全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

很棒的vue弹窗组件

弹窗是一个项目必备的复用利器,所以封装起来,保证项目ui一致,是很有必要的。学了一段时间vue,想想还是用vue写一下吧。用的很小白,但是会写出来了,说明我也有进步一丢丢了。继续加油….
代码贴图如下,样式比较丑,不要介意…

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>ys-vue-modal-component</title>
  <style>
    p,h4{
      margin:0;
    }
    .modal{
      width: 480px;
      background-color: #fff;
      border: 1px solid rgba(0, 0, 0, .3);
      border-radius: 6px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, .5);
      margin: 50px;
    }
    .modal-header {
      color: #fff;
      background: cadetblue;
      border-radius: 6px 6px 0 0;
      padding: 15px;
      border-bottom: 1px solid #5e9fa1;
    }
    .modal-content div {
      padding: 15px 10px;
    }
    .modal-footer {
      padding: 15px;
      text-align: right;
      border-top: 1px solid #e5e5e5;
    }
    .btn {
      border: 1px solid #d1d1d1;
      border-radius: 3px;
      background-color: #f7f7f7;
      background: -webkit-gradient(linear, 0 0, 0 100%, from(#f7f7f7),
     to(#f2f2f2));
      background: -moz-gradient(linear, 0 0, 0 100%, from(#f7f7f7),
     to(#f2f2f2));
      background: -o-gradient(linear, 0 0, 0 100%, from(#f7f7f7), to(#f2f2f2));
      background: -ms-gradient(linear, 0 0, 0 100%, from(#f7f7f7), to(#f2f2f2));
      height: 28px;
      padding: 0 20px;
      cursor: pointer;
      line-height: 28px;
      display: inline-block;
      color: #666666;
      margin-right: 5px;
      outline: none;
    }
    .blue {
       border: 1px solid #5e9fa1;
      background-color: #5e9fa1;
      background: -webkit-gradient(linear, 0 0, 0 100%, from(#74c4c6),
     to(#5e9fa1));
      background: -moz-gradient(linear, 0 0, 0 100%, from(#74c4c6),
     to(#5e9fa1));
      background: -o-gradient(linear, 0 0, 0 100%, from(#74c4c6), to(#5e9fa1));
      background: -ms-gradient(linear, 0 0, 0 100%, from(#74c4c6), to(#5e9fa1));
      color: #FFFFFF;
    }    
  </style>
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
  <div id="app"> 
    <input type="button" class="btn blue" value="点击我,呼唤弹窗,再来一遍" v-if="isHide" @click="isHide=!isHide">
    <ys-modal-component 
       v-if="!isHide"
       modal-title="温馨提示" 
       ok-btn="确认购买" 
       cancel-btn="去意已决"
       @on-ok="ok"
       @on-cancel="cancel"
     >
      <div slot="modal-content">
        尊敬的用户,您购买的商品将于支付成功后3-7个工作日内发货,敬请周知。祝您购物愉快!
      </div>
    </ys-modal-component>
  </div>
  <script>
    /*
      props:
        modalTitle: 弹窗标题
        okBtn: 确认按钮
        cancelBtn: 取消按钮
        注意事项:传参时候使用烤串的书写方式xx-xxx
      slot:
        modal-content: 内容区域
        modal-footer: 页脚按钮区域
      methods: 
        okHandle: 触发确认on-ok自定义事件
        cancelHandle: 触发取消on-cancel自定义事件
     */
    Vue.component('ys-modal-component', {
      props: {
        modalTitle: {
          type: String,
          default: '标题区域'
        },
        okBtn: {
          type: String,
          default: '确认'
        },
        cancelBtn: {
          type: String,
          default: '取消'
        }
      },
      template: `
        <div class="modal">
          <div class="modal-header">
            <h4>{{ modalTitle }}</h4>
          </div>
          <div class="modal-content">
            <div>
              <slot name="modal-content">内容区域</slot>
            </div>
          </div>
          <div class="modal-footer">
              <input class="btn blue" type="button" v-model="okBtn" @click="okHandle" />
              <input class="btn" type="button" v-model="cancelBtn" @click="cancelHandle" />
          </div>
        </div>
      `,
      methods: {
        okHandle () {
          console.log("点击确定");
          this.$emit("on-ok"); 
        },
        cancelHandle () {
          console.log("点击取消");
          this.$emit("on-cancel");
        }
      }
    })


    new Vue({
      el: "#app",
      data: {
        isHide: false
      },
      methods: {
        ok () {
          alert("欢迎您购买本产品");
        },
        cancel () {
          this.isHide = !this.isHide;
        }
      }
    })
  </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue  # 弹窗  # 组件  # 使用Vue组件实现一个简单弹窗效果  # vue实现弹窗引用另一个页面窗口  # Vue弹窗的两种实现方式实例详解  # vue 实现一个简单的全局调用弹窗案例  # 手把手教你使用Vue实现弹窗效果  # 自定义  # 周知  # 是一个  # 来了  # 也有  # 欢迎您  # 很有  # 一遍  # 将于  # 再来  # 温馨提示  # 学了  # 祝您  # 大家多多  # 复用  # rgba  # solid  # border  # radius  # shadow 


相关文章: 制作网站的模板软件,网站怎么建设?  详解jQuery中基本的动画方法  怀化网站制作公司,怀化新生儿上户网上办理流程?  如何打造高效商业网站?建站目的决定转化率  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  建站主机数据库如何配置才能提升网站性能?  广州商城建站系统开发成本与周期如何控制?  如何快速查询网址的建站时间与历史轨迹?  宝塔面板如何快速创建新站点?  详解jQuery停止动画——stop()方法的使用  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何在IIS7中新建站点?详细步骤解析  制作企业网站建设方案,怎样建设一个公司网站?  html制作网站的步骤有哪些,iapp如何添加网页?  建站OpenVZ教程与优化策略:配置指南与性能提升  如何挑选最适合建站的高性能VPS主机?  高端网站建设与定制开发一站式解决方案 中企动力  建站之星CMS五站合一模板配置与SEO优化指南  公司网站的制作公司,企业网站制作基本流程有哪些?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  网站企业制作流程,用什么语言做企业网站比较好?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  南平网站制作公司,2025年南平市事业单位报名时间?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  香港服务器如何优化才能显著提升网站加载速度?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  javascript基本数据类型及类型检测常用方法小结  公司门户网站制作流程,华为官网怎么做?  css网站制作参考文献有哪些,易聊怎么注册?  临沂网站制作企业,临沂第三中学官方网站?  如何高效利用亚马逊云主机搭建企业网站?  制作营销网站公司,淘特是干什么用的?  微信小程序 五星评分(包括半颗星评分)实例代码  实惠建站价格推荐:2025年高性价比自助建站套餐解析  如何在腾讯云服务器上快速搭建个人网站?  如何通过虚拟主机空间快速建站?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  建站之星3.0如何解决常见操作问题?  建站之星客服服务时间及联系方式如何?  如何访问已购建站主机并解决登录问题?  建站之星如何一键生成手机站?  建站10G流量真的够用吗?如何应对访问高峰?  如何通过FTP空间快速搭建安全高效网站?  如何通过宝塔面板实现本地网站访问?  如何快速搭建虚拟主机网站?新手必看指南  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  如何彻底删除建站之星生成的Banner? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。