cocomodal弹框插件 (原创)

所属分类:UI-弹出层,工具提示

 16587  102  查看评论 (6)
分享到微信朋友圈
X
cocomodal弹框插件 (原创) ie兼容12

更新时间:2021-01-03 23:49:41

coco-modal

coco-modal是一个简单实用的javascript弹框插件, 兼容主流浏览器,兼容至ie9 (ie9没有动画效果)

用法

通过npm安装:

npm install coco-modal -S
import coco from 'coco-modal'
  
coco('hello world')
<script src="https://unpkg.com/coco-modal/coco-modal.min.js"></script>

基本用法

<style>
    body{
            margin:0
        }
        .root {
          width: 1000px;
          height: 2000px;
          background-color: #f1f1f2;
          margin: 0 auto; 
          }

</style>
<div class="root"></div>
<script src="https://unpkg.com/coco-modal/coco-modal.min.js"></script>
<script>
    window.CocoConfig = {
        buttonColor: '#e71e63'
    }
    let root = document.body.querySelector(".root");
    let count = 0;
    root.addEventListener("click", () => {
        let n = count++ % 3;
        n === 0 && coco("hello world");
        n === 1 && coco.alert("alert");
        n === 2 && coco.confirm("confirm");
    });
</script>

显示一个输入框

<style>
    body{
            margin:0
        }
        .root {
          width: 1000px;
          height: 2000px;
          background-color: #f1f1f2;
          margin: 0 auto;
        }
</style>
<div class="root"></div>
<script src="https://unpkg.com/coco-modal/coco-modal.min.js"></script>
<script>
    window.CocoConfig = {
        buttonColor: '#e71e63'
    }

    let root = document.body.querySelector(".root");
    root.addEventListener("click", () => {
        coco({
            title: "验证输入",
            inputAttrs: {
                placeholder: "your name",
            },
        }).onClose((cc, isOk, done) => {
            console.log(cc.closeType);
            if (isOk) {
                if (cc.inputValue.trim() === "") {
                    cc.setErrorText("输入不能为空!");
                } else {
                    cc.setErrorText("");
                    cc.inputEl.value = "";
                    done();
                }
            } else {
                done();
            }
        });
    });
</script>

window.CocoConfig 接收的参数作用所有的modal,单个modal的参数会覆盖全局参数

{
    el: null, // 一个dom节点或者选择器  el: '#login'
    maskClose: true,
    header: true,
    footer: true,
    title: '提示',
    text: '',
    width: '500px',
    top: '15vh',
    inputAttrs: false,
    escClose: true,
    okButton: true,
    cancelButton: true,
    okText: '确定',
    cancelText: '取消',
    closeButton: true,
    html: '',
    zIndexOfModal: 1995,
    zIndexOfMask: 2008,
    zIndexOfActiveModal: 2020,
    autoFocusOkButton: true,
    autoFocusInput: true,
    fullScreen: false,
    borderRadius: '6px',
    blur: false,
    buttonColor: '#4285ff',
    onMount() {},
    hooks: {
        open() {},
        opened() {},
        close() {},
        closed() {}
    },
    destroy: false,
    animation: true
}
相关插件-弹出层,工具提示

四种简单弹窗 — 自己配置弹窗

四种弹出方式,可以非常简单的通过修改css来定义自己喜欢的样式。
  弹出层
 53306  423

flavr―超级漂亮的jQuery扁平弹出对话框

flavr是一个时尚的扁平弹出对话框为您的下一个网站。flavr是响应设计布局,能够适应任何屏幕大小。得到最好的用户体验,使用流行的animate.css动画,最重要的是,flavr可以运行在任何新的浏览器IE8(+),任何设备和屏幕大小。
  弹出层
 144836  1135

带动画效果jQuery+CSS3实现的弹出框弹出层效果

带动画效果jQuery+CSS3实现的弹出框弹出层效果
  弹出层
 90405  454

一款简单实用的弹窗插件JMask(原创)

JMask是一款遮罩插件,其小巧灵活,在项目开发中方便实用。使用方式也特别简单,只需要引入一个js文件,该插件基于JQuery开发,所以使用之前需要引入JQuery文件。
  弹出层
 39223  361

讨论这个项目(6)回答他人问题或分享插件使用方法奖励jQ币 评论用户自律公约

    xue-shuai 0
    2021/6/24 14:42:51
    有没有更详细的文档,比如每个参数的作用 回复
    BLUEblue? 0
    2021/5/31 14:36:04
    谢艳军 0
    2021/1/4 9:55:59
    会阻塞吗?
        panyi0
        2021/1/7 15:03:37
        不会
        13752359760
        2021/3/27 22:09:56
        阻塞什么
        BLUEblue?0
        2021/5/31 14:36:24
        什么意思
    回复
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
取消回复