1.jquery.custombox.js
以页面元素为模板填充进对话框内容体,或者获取远程数据填充进内容体,实现PPT似的3D动效。
插件写作引入jquery,按原生js写就,效果依赖于支持css3以及Dom3级的浏览器,因此不包括ie8、ie9。
?
css源码:
/*
 *  jQuery Custombox v1.1.3 - 2014/02/18
 *  jQuery Modal Window Effects.
 *  http://dixso.github.io/custombox/
 *  (c) 2014 Julio De La Calle - http://dixso.net - @dixso9
 *
 *  Under MIT License - http://www.opensource.org/licenses/mit-license.php
 */
/*
 -------------------------------------------------
 Overlay
 -------------------------------------------------
 */
.custombox-overlay {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
}
/*
 -------------------------------------------------
 Modal
 -------------------------------------------------
 */
.custombox-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    backface-visibility: hidden;/* 隐藏旋转元素的背面 */
    -webkit-transform: translateY(-50%);/* 根据自身的尺寸大小向上移动50% */
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}
.custombox-modal {
    height: auto;
    visibility: hidden;
}
/*
 -------------------------------------------------
 Error
 -------------------------------------------------
 */
.custombox-error {
    padding: 20px;
    text-align: center;
    color: #F00;
    font-weight: bold;
    font-size: 14px;
    background-color: #FFF;
    border-radius: 5px;
}
/*
 -------------------------------------------------
 Actions
 -------------------------------------------------
 */
.custombox-show {
    visibility: visible;
}
.custombox-show ~ .custombox-overlay {
    opacity: 1;
    visibility: visible;
}
.custombox-perspective,
.custombox-perspective body {
    height: 100%;
    overflow: hidden;
}
.custombox-perspective body  {
    -webkit-perspective: 600px;/* 创建容器的景深,3D效果,容器内部子元素有3D透视效果,绘图中的透视画法 */
    perspective: 600px;
}
.custombox-container {
    min-height: 100%;
}
.custombox-hide-scrollbar {
    overflow-y: hidden;
}
.custombox-hide-scrollbar body {
    position: relative;
    overflow: hidden;
}
/*
 -------------------------------------------------
 Fade in and scale up
 -------------------------------------------------
 */
.custombox-fadein .custombox-modal-content {
    -webkit-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;/* 所有属性改变的平滑过渡效果,即缩放scale */
    opacity: 0;
}
.custombox-show.custombox-fadein .custombox-modal-content {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
}
/*
 -------------------------------------------------
Slide and stick to top
 -------------------------------------------------
 */
.custombox-slide-top {
    top: 0;
}
.custombox-slide-top .custombox-modal-content,
.custombox-close.custombox-slide-left-top .custombox-modal-content,
.custombox-close.custombox-slide-right-top .custombox-modal-content {
    -webkit-transform: translateY(-200%);
    -ms-transform: translateY(-200%);
    transform: translateY(-200%);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    opacity: 0;
}
.custombox-show.custombox-slide-top .custombox-modal-content {
    -webkit-transform: translateY(0%);
    -ms-transform: translateY(0%);
    transform: translateY(0%);
    border-radius: 0 0 3px 3px;
    opacity: 1;
}
.custombox-close.custombox-slide-top-bottom .custombox-modal-content,
.custombox-close.custombox-slide-right-bottom .custombox-modal-content,
.custombox-close.custombox-slide-bottom-bottom .custombox-modal-content,
.custombox-close.custombox-slide-left-bottom .custombox-modal-content {
    -webkit-transform: translateY(200%);
    -ms-transform: translateY(200%);
    transform: translateY(200%);
}
/*
 -------------------------------------------------
 Slide from the right
 -------------------------------------------------
 */
.custombox-slide-right .custombox-modal-content,
.custombox-close.custombox-slide-bottom-right .custombox-modal-content,
.custombox-close.custombox-slide-top-right .custombox-modal-content,
.custombox-close.custombox-slide-center-right .custombox-modal-content {
    -webkit-transform: translateX(20%);
    -ms-transform: translateX(20%);
    transform: translateX(20%);
    opacity: 0;
    -webkit-transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    -ms-transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-slide-right .custombox-modal-content {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
}
.custombox-close.custombox-slide-right-left .custombox-modal-content {
    -webkit-transform: translateX(-20%);
    -ms-transform: translateX(-20%);
    transform: translateX(-20%);
}
/*
 -------------------------------------------------
Slide from the bottom
 -------------------------------------------------
 */
.custombox-slide-bottom .custombox-modal-content {
    -webkit-transform: translateY(20%);
    -ms-transform: translateY(20%);
    transform: translateY(20%);
    opacity: 0;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-slide-bottom .custombox-modal-content {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
}
.custombox-close.custombox-slide-bottom-top .custombox-modal-content {
    -webkit-transform: translateY(-20%);
    -ms-transform: translateY(-20%);
    transform: translateY(-20%);
}
/*
 -------------------------------------------------
 Slide from the left
 -------------------------------------------------
 */
.custombox-slide-left .custombox-modal-content,
.custombox-close.custombox-slide-top-left .custombox-modal-content,
.custombox-close.custombox-slide-center-left .custombox-modal-content {
    -webkit-transform: translateX(-20%);
    -ms-transform: translateX(-20%);
    transform: translateX(-20%);
    opacity: 0;
    -webkit-transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    -ms-transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    transition-timing-function: cubic-bezier(0.25, 0.5, 0.5, 0.9);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-slide-left .custombox-modal-content {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
}
.custombox-close.custombox-slide-left-right .custombox-modal-content {
    -webkit-transform: translateX(20%);
    -ms-transform: translateX(20%);
    transform: translateX(20%);
}
/*
 -------------------------------------------------
Slide and stick to center
 -------------------------------------------------
 */
.custombox-slide-center .custombox-modal-content {
    -webkit-transform: translateY(-200%);
    -ms-transform: translateY(-200%);
    transform: translateY(-200%);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    opacity: 0;
}
.custombox-show.custombox-slide-center .custombox-modal-content {
    -webkit-transform: translateY(0%);
    -ms-transform: translateY(0%);
    transform: translateY(0%);
    border-radius: 0 0 3px 3px;
    opacity: 1;
}
/*
 -------------------------------------------------
Newspaper
 -------------------------------------------------
 */
.custombox-newspaper .custombox-modal-content {
    -webkit-transform: scale(0) rotate(720deg);
    -ms-transform: scale(0) rotate(720deg);
    transform: scale(0) rotate(720deg);
    opacity: 0;
}
.custombox-show.custombox-newspaper ~ .custombox-overlay,
.custombox-newspaper .custombox-modal-content {
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-newspaper .custombox-modal-content {
    -webkit-transform: scale(1) rotate(0deg);
    -ms-transform: scale(1) rotate(0deg);
    transform: scale(1) rotate(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
Fall
 -------------------------------------------------
 */
.custombox-fall.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-fall .custombox-modal-content {
    -webkit-transform-style: preserve-3d;/* 元素及子元素保持3D变换效果 */
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: translateZ(600px) rotateX(20deg);
    /*  translateZ正值,3D效果离用户更近,也就是更大 */
    /*  rotateX元素绕X轴旋转 */
    -ms-transform: translateZ(600px) rotateX(20deg);
    transform: translateZ(600px) rotateX(20deg);
    opacity: 0;
}
.custombox-show.custombox-fall .custombox-modal-content {
    -webkit-transition-timing-function: ease-in;
    -ms-transition-timing-function: ease-in;
    transition-timing-function: ease-in;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    -webkit-transform: translateZ(0) rotateX(0deg);
    -ms-transform: translateZ(0) rotateX(0deg);
    transform: translateZ(0) rotateX(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
Side fall
 -------------------------------------------------
 */
.custombox-sidefall.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-sidefall .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: translate(30%) translateZ(600px) rotate(10deg);
    -ms-transform: translate(30%) translateZ(600px) rotate(10deg);
    transform: translate(30%) translateZ(600px) rotate(10deg);
    opacity: 0;
}
.custombox-show.custombox-sidefall .custombox-modal-content {
    -webkit-transition-timing-function: ease-in;
    -ms-transition-timing-function: ease-in;
    transition-timing-function: ease-in;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    -webkit-transform: translate(0%) translateZ(0) rotate(0deg);
    -ms-transform: translate(0%) translateZ(0) rotate(0deg);
    transform: translate(0%) translateZ(0) rotate(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
Blur
 -------------------------------------------------
 */
.custombox-show.custombox-blur ~ .custombox-container * {
    text-shadow: 0 0 5px rgba(0,0,0,0.5);
    color: transparent;
}
.custombox-show.custombox-blur ~ .custombox-container img {
    -webkit-filter: blur(10px);
    -moz-filter: blur(10px);
    -ms-filter: blur(10px);
    filter: blur(10px);/* 模糊滤镜 */
}
.custombox-blur .custombox-modal-content {
    -webkit-transform: translateY(-5%);
    -ms-transform: translateY(-5%);
    transform: translateY(-5%);
    opacity: 0;
}
.custombox-blur .custombox-modal-content,
.custombox-show.custombox-blur ~ .custombox-container {
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-blur .custombox-modal-content {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
}
/*
 -------------------------------------------------
3D Flip horizontal
 -------------------------------------------------
 */
.custombox-flip-horizontal.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-flip-horizontal .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: rotateY(-70deg);
    transform: rotateY(-70deg);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    opacity: 0;
}
.custombox-show.custombox-flip-horizontal .custombox-modal-content {
    -webkit-transform: rotateY(0deg);
    -ms-transform: rotateY(0deg);
    transform: rotateY(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
3D Flip vertical
 -------------------------------------------------
 */
.custombox-flip-vertical.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-flip-vertical .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: rotateX(-70deg);
    -ms-transform: rotateX(-70deg);
    transform: rotateX(-70deg);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
    opacity: 0;
}
.custombox-show.custombox-flip-vertical .custombox-modal-content {
    -webkit-transform: rotateX(0deg);
    -ms-transform: rotateX(0deg);
    transform: rotateX(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
3D Sign
 -------------------------------------------------
 */
.custombox-sign.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-sign .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: rotateX(-60deg);
    -ms-transform: rotateX(-60deg);
    transform: rotateX(-60deg);
    -webkit-transform-origin: 50% 0;
    -ms-transform-origin: 50% 0;
    transform-origin: 50% 0;/* transform-origin默认是50% 50% */
    opacity: 0;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-sign .custombox-modal-content {
    -webkit-transform: rotateX(0deg);
    -ms-transform: rotateX(0deg);
    transform: rotateX(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
Super scaled
 -------------------------------------------------
 */
.custombox-superscaled .custombox-modal-content {
    -webkit-transform: scale(2);
    -ms-transform: scale(2);
    transform: scale(2);
    opacity: 0;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-superscaled .custombox-modal-content {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    opacity: 1;
}
/*
 -------------------------------------------------
3D Slit
 -------------------------------------------------
 */
.custombox-slit.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-slit .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: translateZ(-3000px) rotateY(90deg);
    -ms-transform: translateZ(-3000px) rotateY(90deg);
    transform: translateZ(-3000px) rotateY(90deg);
    opacity: 0;
}
.custombox-show.custombox-slit .custombox-modal-content {
    -webkit-animation: slit .7s forwards ease-out;
    -ms-animation: slit .7s forwards ease-out;
    animation: slit .7s forwards ease-out;
}
@-webkit-keyframes slit {
    50% { -webkit-transform: translateZ(-250px) rotateY(89deg); opacity: .5; -webkit-animation-timing-function: ease-out;}
    100% { -webkit-transform: translateZ(0) rotateY(0deg); opacity: 1; }
}
@-ms-keyframes slit {
    50% { -ms-transform: translateZ(-250px) rotateY(89deg); opacity: .5; -ms-animation-timing-function: ease-out;}
    100% { -ms-transform: translateZ(0) rotateY(0deg); opacity: 1; }
}
@keyframes slit {
    50% { transform: translateZ(-250px) rotateY(89deg); opacity: 1; animation-timing-function: ease-out;}
    100% { transform: translateZ(0) rotateY(0deg); opacity: 1; }
}
/*
 -------------------------------------------------
3D Rotate from bottom
 -------------------------------------------------
 */
.custombox-rotate-bottom.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-rotate-bottom .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: translateY(100%) rotateX(90deg);
    -ms-transform: translateY(100%) rotateX(90deg);
    transform: translateY(100%) rotateX(90deg);
    -webkit-transform-origin: 0 100%;
    -ms-transform-origin: 0 100%;
    transform-origin: 0 100%;
    opacity: 0;
    -webkit-transition-timing-function: ease-out;
    -ms-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-rotate-bottom .custombox-modal-content {
    -webkit-transform: translateY(0%) rotateX(0deg);
    -ms-transform: translateY(0%) rotateX(0deg);
    transform: translateY(0%) rotateX(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
3D Rotate in from left
 -------------------------------------------------
 */
.custombox-rotate-left.custombox-modal {
    -webkit-perspective: 1300px;
    -ms-perspective: 1300px;
    perspective: 1300px;
}
.custombox-rotate-left .custombox-modal-content {
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transform: translateZ(100px) translateX(-30%) rotateY(90deg);
    -ms-transform: translateZ(100px) translateX(-30%) rotateY(90deg);
    transform: translateZ(100px) translateX(-30%) rotateY(90deg);
    -webkit-transform-origin: 0 100%;
    -ms-transform-origin: 0 100%;
    transform-origin: 0 100%;
    opacity: 0;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-rotate-left .custombox-modal-content {
    -webkit-transform: translateZ(0px) translateX(0%) rotateY(0deg);
    -ms-transform: translateZ(0px) translateX(0%) rotateY(0deg);
    transform: translateZ(0px) translateX(0%) rotateY(0deg);
    opacity: 1;
}
/*
 -------------------------------------------------
Slide in from bottom with perspective on container
 -------------------------------------------------
 */
.custombox-show.custombox-letmein ~ .custombox-container {
    height: 100%;
    overflow: hidden;
    -webkit-transition-property: -webkit-transform;
    -ms-transition-property: -ms-transform;
    transition-property: transform;
}
.custombox-show.custombox-letmein ~ .custombox-container,
.custombox-show.custombox-letmein ~ .custombox-overlay  {
    -webkit-transform: rotateX(-2deg);
    -ms-transform: rotateX(-2deg);
    transform: rotateX(-2deg);
    -webkit-transform-origin: 50% 0%;
    -ms-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    -webkit-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
}
.custombox-letmein .custombox-modal-content {
    opacity: 0;
    -webkit-transform: translateY(200%);
    -ms-transform: translateY(200%);
    transform: translateY(200%);
}
.custombox-show.custombox-letmein .custombox-modal-content {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
/*
 -------------------------------------------------
Slide from right with perspective on container
 -------------------------------------------------
 */
.custombox-show.custombox-makeway ~ .custombox-container {
    height: 100%;
    overflow: hidden;
}
.custombox-show.custombox-makeway ~ .custombox-overlay {
    background: rgba(143,27,15,0.8);
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-makeway ~ .custombox-container,
.custombox-show.custombox-makeway ~ .custombox-overlay {
    -webkit-transform-style: preserve-3d;
    -webkit-transform-origin: 0% 50%;
    -webkit-animation: rotateRightSideFirst 0.5s forwards ease-in;
    -ms-transform-style: preserve-3d;
    -ms-transform-origin: 0% 50%;
    -ms-animation: rotateRightSideFirst 0.5s forwards ease-in;
    transform-style: preserve-3d;
    transform-origin: 0% 50%;
    animation: rotateRightSideFirst 0.5s forwards ease-in;
}
@-webkit-keyframes rotateRightSideFirst {
    50% { -webkit-transform: translateZ(-50px) rotateY(5deg); -webkit-animation-timing-function: ease-out; }
    100% { -webkit-transform: translateZ(-200px); }
}
@-ms-keyframes rotateRightSideFirst {
    50% { -ms-transform: translateZ(-50px) rotateY(5deg); -ms-animation-timing-function: ease-out; }
    100% { -ms-transform: translateZ(-200px); }
}
@keyframes rotateRightSideFirst {
    50% { transform: translateZ(-50px) rotateY(5deg); animation-timing-function: ease-out; }
    100% { transform: translateZ(-200px); }
}
.custombox-makeway .custombox-modal-content {
    -webkit-transform: translateX(200%);
    -ms-transform: translateX(200%);
    transform: translateX(200%);
    opacity: 0;
}
.custombox-show.custombox-makeway .custombox-modal-content {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
/*
 -------------------------------------------------
Slip in from the top with perspective on container
 -------------------------------------------------
 */
.custombox-show.custombox-slip ~ .custombox-container {
    height: 100%;
    overflow: hidden;
}
.custombox-show.custombox-slip ~ .custombox-overlay {
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
.custombox-show.custombox-slip ~ .custombox-container,
.custombox-show.custombox-slip ~ .custombox-overlay {
    -webkit-transform-style: preserve-3d;
    -webkit-transform-origin: 50% 100%;
    -webkit-animation: OpenTop 0.5s forwards ease-in;
    -ms-transform-style: preserve-3d;
    -ms-transform-origin: 50% 100%;
    -ms-animation: OpenTop 0.5s forwards ease-in;
    transform-style: preserve-3d;
    transform-origin: 50% 100%;
    animation: OpenTop 0.5s forwards ease-in;
}
@-webkit-keyframes OpenTop {
    50% {
        -webkit-transform: rotateX(10deg);
        -webkit-animation-timing-function: ease-out;
    }
}
@-ms-keyframes OpenTop {
    50% {
        -ms-transform: rotateX(10deg);
        -ms-animation-timing-function: ease-out;
    }
}
@keyframes OpenTop {
    50% {
        transform: rotateX(10deg);
        animation-timing-function: ease-out;
    }
}
.custombox-slip .custombox-modal-content {
    -webkit-transform: translateY(-200%);
    -ms-transform: translateY(-200%);
    transform: translateY(-200%);
    opacity: 0;
}
.custombox-show.custombox-slip .custombox-modal-content {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
    -webkit-transition-property: all;
    -ms-transition-property: all;
    transition-property: all;
}
?
js源码:
/**
 * 引入jquery同时使用原生js,其余代码的手法更像探索而不够成熟;
 */
/**
 * 用途:
 * 以页面元素为模板或者通过远程数据创建Dom元素,调整显示样式,实现动效显示;
 *     页面模板通过href以#、.开头配置,或者options.url配置;
 * 
 * 实现思路:
 * document.createElement创建的对象包含css、style、id属性(初始时缩放样式等),赋值后插入页面;
 * 插件通过_create方法创建对话框包裹元素,设置css属性,进而用_box.create方法插入页面;
 *     _box.build方法将对话框内容体插入包裹元素中,调整显示样式,添加transition-duration样式,添加custombox-show最后呈现样式;
 <style>
    .custombox-fadein .custombox-modal-content {
        -webkit-transform: scale(0.7);
        -ms-transform: scale(0.7);
        transform: scale(0.7);
        -webkit-transition-property: all;
        -ms-transition-property: all;
        transition-property: all;
        opacity: 0;
    }
    .custombox-show.custombox-fadein .custombox-modal-content {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 1;
    }
</style>
<script type="text/javascript">
    var dom=document.getElementsByClassName("custombox-fadein")[0];
    document.getElementsByClassName("custombox-modal-content")[0].style["transition-duration"]="300ms";
    setTimeout(function(){
    dom.className=dom.className+" custombox-show";
    },300)
</script>
 *
 * 怎样使用时间戳避免多次产生实例???
 */
/**
 * 样式:IE:div.style.fontSize="14px";
 *      Else:div.style.setProperty("font-size","14px"); 按情况添加-webkit-、-ms-前缀;
 *
 * document.defaultView.getComputedStyle(elems[i],null).getPropertyValue(‘z-index‘);
 *
 * window.scrollTo();
 *
 * document.body.insertBefore(modal, document.body.firstChild);
 *
 * ‘onorientationchange‘垂直或水平翻转设备时触发;
 *
 * var onCloseLaunch=new Function(‘onClose‘,‘return ‘+onClose )(onClose);同eval相似,将onClose传入函数以声名该函数;
 *     onCloseLanch()执行,其中参数onClose是有待执行的函数声明;
 *     第一对括号中,首参为参数名,次参为执行的函数体;第二对括号传入具体的参数;
 *     事件监听和触发在此基础上写就??? */
/*
 *  jQuery Custombox v1.1.3 - 2014/02/18
 *  jQuery Modal Window Effects.
 *  http://dixso.github.io/custombox/
 *  (c) 2014 Julio De La Calle - http://dixso.net - @dixso9
 *
 *  Under MIT License - http://www.opensource.org/licenses/mit-license.php
 */
// the semi-colon before function invocation is a safety net against concatenated
// scripts and/or other plugins which may not be closed properly.
;(function ( $, window, document, undefined ) {
    "use strict";
    // undefined is used here as the undefined global variable in ECMAScript 3 is
    // mutable (ie. it can be changed by someone else). undefined isn‘t really being
    // passed in so we can ensure the value of it is truly undefined. In ES5, undefined
    // can no longer be modified.
    // window and document are passed through as local variable rather than global
    // as this (slightly) quickens the resolution process and can be more efficiently
    // minified (especially when both are regularly referenced in your plugin).
    // Create the defaults once.
    var cb = ‘custombox‘,
        defaults = {
            url:            null,           // Set the URL, ID or Class.
            // 当url以#或.开头时,以页面上的某个元素作为模板渲染对话框
            cache:          false,          // If set to false, it will force requested pages not to be cached by the browser only when send by AJAX.
            escKey:         true,           // Allows the user to close the modal by pressing ‘ESC‘.
            eClose:         null,           // Element ID or Class for to be close the modal.
            zIndex:         9999,           // Overlay z-index: Number or auto.
            overlay:        true,           // Show the overlay.
            overlayColor:   ‘#000‘,         // Overlay color.
            overlayOpacity: 0.8,            // The overlay opacity level. Range: 0 to 1.
            overlayClose:   true,           // Allows the user to close the modal by clicking the overlay.
            overlaySpeed:   200,            // Sets the speed of the overlay, in milliseconds.
            customClass:    null,           // Custom class to modal.
            width:          null,           // Set a fixed total width.
            height:         null,           // Set a fixed total height.
            effect:         ‘fadein‘,       // fadein | slide | newspaper | fall | sidefall | blur | flip | sign | superscaled | slit | rotate | letmein | makeway | slip | blur.
            position:       null,           // Only with effects: slide, flip and rotate. (top, right, bottom, left and center) | (vertical or horizontal) and output position sseparated by commas. Ex: ‘top, bottom‘.
            speed:          600,            // Sets the speed of the transitions, in milliseconds.
            open:           null,           // Callback that fires right before begins to open.
            complete:       null,           // Callback that fires right after loaded content is displayed.
            close:          null,           // Callback that fires once is closed.
            responsive:     true,           // Sets if you like box responsive or not.
            scrollbar:      false,          // Show scrollbar or hide automatically.
            error:          ‘Error 404!‘    // Text to be displayed when there is an error.
        };
    // The plugin constructor.
    function Plugin ( element, options ) {
        this.element = element;
        // Get the max zIndex.
        if ( typeof this.element === ‘object‘ && typeof options === ‘object‘ && isNaN( options.zIndex ) && options.zIndex === ‘auto‘ ) {
            options.zIndex = ( this._isIE() ? defaults.zIndex : this._zIndex() );
        }
        // Merge objects.
        this.settings = this._extend( {}, defaults, options );
        if ( typeof this.element === ‘object‘ ) {
            // Private method.
            this._box.init( this );
        } else {
            // Public method.
            this[this.element]();
        }
    }
    Plugin.prototype = {
        /*
         ----------------------------
         Private methods
         ----------------------------
         */
         /*
          * _overlay创建灰色浮层;
          * _box.init根据setting.url或者调用ajax方式,或者以某元素为模板,或者直接创建错误提示对话框;
          * _box.create创建对话框包裹元素modal、内容体content,插入到页面尾部;
                包裹元素modal添加自定义样式类setting.customClass,调用_box.effect方法添加动效样式;
                内容体content添加动效持续时间transition-duration:obj.settings.speed+‘ms‘;
                根据settings.overlay配置调用_overlay添加灰色浮层面板;
                返回包裹元素modal、内容体content,数组形式;
          * _box.effect根据setting.effect、effect.position获取动效样式;
                newspaper、fall、sidefall、blur、sign、superscaled、slit、letmein、makeway、slip、blur动效返回custombox-[effect];
                slide、flip、rotate返回custombox-slide-top或custombox-slide-top custombox-slide-top;
                letmein、makeway、slip、blur需要将body内元素添加到custombox-container容器中,letmein、makeway、slip需要给html添加perspective样式;
                效果是实现整个页面的缩放、或者页面显出翻页效果;
          * _box.build将对话框内容体插入包裹元素中,并调整对话框内容体的宽度、是否显示滚动条等样式信息,并绑定事件;
          * _box.responsive(obj,tmp,modal,wsize)响应式调整对话框尺寸,wsize是屏幕的尺寸;
          * _box.ajax获取远程数据,以responseText为文本创建div,调用_box.build渲染后显示;
          * _close重置对话框样式,触发setting.close函数执行;
          * _listeners绑定对话框关闭事件,点击灰色浮层关闭、esc关闭、某元素关闭;
          *     setting.close函数该函数赋值给data属性以供_close方法调用该函数;
          */
        _overlay: function() {
            var rgba = this._hexToRgb(this.settings.overlayColor),
                styles = {};
            // Only IE 8
            if ( navigator.appVersion.indexOf(‘MSIE 8.‘) != -1 ) {
                styles.backgroundColor = this.settings.overlayColor;
                styles.zIndex =  parseFloat(this.settings.zIndex) + 1;
                styles.filter = ‘alpha(opacity=‘ + this.settings.overlayOpacity * 100 + ‘)‘;
            } else {
                styles[‘background-color‘] = ‘rgba(‘ + rgba.r + ‘,‘ + rgba.g + ‘, ‘ + rgba.b + ‘,‘ + this.settings.overlayOpacity + ‘)‘;
                styles[‘z-index‘] =  parseFloat(this.settings.zIndex) + 1;
                styles[‘transition‘] = ‘all ‘ + this.settings.overlaySpeed / 1000 + ‘s‘;
            }
            document.getElementsByTagName(‘body‘)[0].appendChild(this._create({
                id:     ‘overlay‘,
                eClass: ‘overlay‘
            }, styles));
        },
        _box: {
            init: function ( obj ) {
                // Check if callback ‘open‘.
                if ( obj.settings.open && typeof obj.settings.open === ‘function‘ ) {
                    obj.settings.open( undefined !== arguments[0] ? arguments[0] : ‘‘ );
                }
                // Check ‘href‘.
                if ( obj.settings.url === null ) {
                    if ( obj.element !== null ) {
                        obj.settings.url = obj.element.getAttribute(‘href‘);
                    }
                }
                if ( typeof obj.settings.url === ‘string‘ ) {
                    if ( obj.settings.url.charAt(0) === ‘#‘ || obj.settings.url.charAt(0) === ‘.‘ ) {
                        // Inline.
                        if ( document.querySelector(obj.settings.url) ) {
                            obj._box.build( obj, document.querySelector(obj.settings.url).cloneNode(true) );
                        } else {
                            obj._box.build( obj, null );
                        }
                    } else {
                        // Ajax.
                        this.ajax( obj );
                    }
                } else {
                    obj._box.build( obj, null );
                }
            },
            create: function ( obj ) {
                var styles = {};
                if ( obj._isIE() ) {
                    styles.zIndex =  parseFloat(obj.settings.zIndex) + 2;
                } else {
                    styles[‘z-index‘] =  parseFloat(obj.settings.zIndex) + 2;
                }
                var modal = obj._create({
                        id:                     ‘modal‘,
                        eClass:                 ‘modal ‘ + obj._box.effect( obj ) + ( obj.settings.customClass ? ‘ ‘ + obj.settings.customClass : ‘‘ )
                    }, styles),
                    content = obj._create({
                        id:                     ‘modal-content‘,
                        eClass:                 ‘modal-content‘
                    }, {
                        ‘transition-duration‘:  obj.settings.speed + ‘ms‘
                    });
                // Insert modal to the content.
                modal.appendChild(content);
                // Insert modal just after the body.
                document.body.insertBefore(modal, document.body.firstChild);
                // Create overlay after the modal content.
                if ( obj.settings.overlay ) {
                    obj._overlay();
                }
                return [modal, content];
            },
            effect: function ( obj ) {
                var position = [‘slide‘,‘flip‘,‘rotate‘],
                    perspective = [‘letmein‘,‘makeway‘,‘slip‘,‘blur‘],
                    effect = cb + ‘-‘ + obj.settings.effect,
                    effectClose = ‘‘;
                // Check if is array.
                if ( obj.settings.position !== null && obj.settings.position.indexOf(‘,‘) !== -1 ) {
                    // Convert the string to array.
                    obj.settings.position = obj.settings.position.split(‘,‘);
                    if( obj.settings.position.length > 1 ) {
                        effectClose = ‘ ‘ + cb + ‘-‘ + obj.settings.effect + ‘-‘ + obj.settings.position[0].replace(/^\s+|\s+$/g, ‘‘) + ‘-‘ + obj.settings.position[1].replace(/^\s+|\s+$/g, ‘‘);
                    }
                }
                // Position.
                for ( var i = 0, len1 = position.length; i < len1; i++ ) {
                    if ( position[i] === obj.settings.effect ) {
                        effect = cb + ‘-‘ + obj.settings.effect + ‘-‘ + ( effectClose !== ‘‘ ? obj.settings.position[0] : obj.settings.position ) + effectClose;
                    }
                }
                // HTML head.
                for ( var x = 0, len2 = perspective.length; x < len2; x++ ) {
                    if ( perspective[x] === obj.settings.effect ) {
                        if ( obj.settings.effect !== ‘blur‘ ) {
                            // Add class.
                            obj._addClass( document.getElementsByTagName( ‘html‘ )[0], ‘perspective‘ );
                        }
                        var div = document.createElement(‘div‘);
                            div.className = cb + ‘-container‘;
                        // Move the body‘s children into this wrapper
                        while ( document.body.firstChild ) {
                            div.appendChild(document.body.firstChild);
                        }
                        // Append the wrapper to the body
                        document.body.appendChild(div);
                    }
                }
                return effect;
            },
            build: function ( obj, modal ) {
                var body = document.body,
                    html = document.documentElement,
                    top = ( html && html.scrollTop  || body && body.scrollTop  || 0 );
                if ( obj.settings.error !== false && typeof obj.settings.error === ‘string‘ ) {
                    // If is null, show message error.
                    if ( modal === null ) {
                        modal = document.createElement(‘div‘);
                        obj._addClass( modal, ‘error‘ );
                        modal.innerHTML = obj.settings.error;
                    }
                    // [0] => modal
                    // [1] => content
                    var tmp = obj._box.create( obj );
                    // Insert content to the modal.
                    tmp[1].appendChild(modal);
                    // Show the content.
                    modal.style.display = ‘block‘;
                    // Set scroll.
                    tmp[0].setAttribute(‘data-‘ + cb + ‘-scroll‘, top);
                    // Temporal sizes.
                    var tmpSize = {
                        width:  parseInt(obj.settings.width, 0),
                        height: parseInt(obj.settings.height, 0)
                    };
                    // Check width: If it is a number and if not null.
                    if ( !isNaN( tmpSize.width ) && tmpSize.width === obj.settings.width && tmpSize.width.toString() === obj.settings.width.toString() && tmpSize.width !== null ) {
                        modal.style.width = tmpSize.width + ‘px‘;
                    }
                    // Check height: If it is a number   and if not null.
                    if ( !isNaN( tmpSize.height ) && tmpSize.height === obj.settings.height && tmpSize.height.toString() === obj.settings.height.toString() && tmpSize.height !== null ) {
                        modal.style.height = tmpSize.height + ‘px‘;
                    }
                    var offw = modal.offsetWidth,
                        position = {
                            ‘margin-left‘:  - offw / 2 + ‘px‘,
                            ‘width‘:        offw + ‘px‘
                        };
                    // IE8 not supported: translateY(-50%).
                    if ( obj._isIE() ) {
                        var offh = modal.offsetHeight;
                        position[‘margin-top‘] = - offh / 2 + ‘px‘;
                        position[‘height‘] = offh + ‘px‘;
                    }
                    // If position top?
                    if ( obj.settings.position !== null && obj.settings.position.indexOf(‘top‘) !== -1 ) {
                        position[‘transform‘] = ‘none‘;
                    }
                    // Center modal.
                    obj._create( {}, position, tmp[0] );
                    // Check if scrollbar is visible.
                    var wsize = {
                        width:  ‘innerWidth‘ in window ? window.innerWidth : document.documentElement.offsetWidth,
                        height: ‘innerHeight‘ in window ? window.innerHeight : document.documentElement.offsetHeight
                    };
                    if ( !obj.settings.scrollbar ) {
                        if ( modal.offsetHeight < wsize.height && body.offsetHeight > wsize.height ) {
                            var outer = obj._create({},{
                                visibility: ‘hidden‘,
                                width:      ‘100px‘
                            });
                            // Append outer.
                            body.appendChild(outer);
                            // Save the width without scrollbar.
                            var widthNoScroll = outer.offsetWidth;
                            // Force scrollbars
                            outer.style.overflow = ‘scroll‘;
                            // Add inner div.
                            var inner = obj._create({},{
                                width: ‘100%‘
                            });
                            // Append inner.
                            outer.appendChild(inner);
                            // Save the width with scrollbar.
                            var widthWithScroll = inner.offsetWidth;
                            // Remove divs
                            outer.parentNode.removeChild(outer);
                            // Hide scrollbar.
                            body.style.marginRight = widthNoScroll - widthWithScroll + ‘px‘;
                            obj._addClass( document.getElementsByTagName( ‘html‘ )[0], ‘hide-scrollbar‘ );
                        } else {
                            obj._scrollbar(tmp[0]);
                        }
                    } else {
                        obj._scrollbar(tmp[0]);
                    }
                    // Launch responsive.
                    if ( obj.settings.responsive ) {
                        obj._box.responsive(obj, tmp, modal, wsize);
                    }
                    // Show modal.
                    setTimeout( function () {
                        // Init listeners.
                        obj._listeners( top );
                        // Show modal.
                        tmp[0].className += ‘ ‘ + cb + ‘-show‘;
                        var script = tmp[1].getElementsByTagName(‘script‘);
                        // Execute the scripts.
                        for ( var i = 0, len = script.length; i < len; i++ ) {
                            new Function( script[i].text )();
                        }
                        if ( window.attachEvent ) {
                            setTimeout( function () {
                                // Check if callback ‘complete‘.
                                if ( obj.settings.complete && typeof obj.settings.complete === ‘function‘ ) {
                                    obj.settings.complete( undefined !== arguments[0] ? arguments[0] : ‘‘ );
                                }
                            }, obj.settings.speed );
                        } else {
                            var stop = true;
                            tmp[0].addEventListener(obj._crossBrowser(), function () {
                                if ( stop ) {
                                    stop = false;
                                    // Check if callback ‘complete‘.
                                    if ( obj.settings.complete && typeof obj.settings.complete === ‘function‘ ) {
                                        obj.settings.complete( undefined !== arguments[0] ? arguments[0] : ‘‘ );
                                    }
                                }
                            }, false);
                        }
                    }, ( obj.settings.overlay ? obj.settings.overlaySpeed : 200 ) );
                }
            },
            responsive: function ( obj, tmp, modal, wsize ) {
                // Store width.
                modal.setAttribute(‘data-‘ + cb + ‘-width‘, modal.offsetWidth);
                // Prepare responsive.
                obj._create( {}, {
                    width: ‘auto‘
                }, modal );
                // The first time.
                if ( wsize.width < modal.offsetWidth ) {
                    obj._create( {}, {
                        width:          wsize.width - 40 + ‘px‘,
                        ‘margin-left‘:  ‘20px‘,
                        ‘margin-right‘: ‘20px‘,
                        ‘left‘:         0
                    }, tmp[0] );
                }
                var supportsOrientationChange = ‘onorientationchange‘ in window,
                    orientationEvent = supportsOrientationChange ? ‘orientationchange‘ : ‘resize‘;
                if ( window.attachEvent ) {
                    window.attachEvent(orientationEvent, function () {
                        modalResize(this);
                    }, false);
                } else {
                    window.addEventListener(orientationEvent, function () {
                        modalResize(this);
                    }, false);
                }
                var modalResize = function ( e ) {
                    if ( typeof window.orientation === ‘undefined‘ ) {
                        if  ( modal.getAttribute(‘data-‘ + cb + ‘-width‘) !== null ) {
                            var wm = modal.getAttribute(‘data-‘ + cb + ‘-width‘);
                            if ( wm > e.innerWidth ) {
                                obj._create( {}, {
                                    width:          e.innerWidth - 40 + ‘px‘,
                                    ‘margin-left‘:  ‘20px‘,
                                    ‘margin-right‘: ‘20px‘,
                                    left:           0
                                }, tmp[0] );
                            } else {
                                obj._create( {}, {
                                    width:          wm + ‘px‘,
                                    ‘margin-left‘:  - wm / 2 + ‘px‘,
                                    ‘left‘:         ‘50%‘
                                }, tmp[0] );
                            }
                        }
                    } else {
                        obj._create( null, {
                            width:          e.innerWidth - 40 + ‘px‘,
                            ‘margin-left‘:  ‘20px‘,
                            ‘margin-right‘: ‘20px‘,
                            left:           0
                        }, tmp[0] );
                    }
                };
            },
            ajax: function ( obj ) {
                var xhr = new XMLHttpRequest();
                xhr.onreadystatechange = function () {// 有关ajax的事件监听等机理???
                    var completed = 4;
                    if( xhr.readyState === completed ) {
                        if( xhr.status === 200 ) {
                            var modal = document.createElement(‘div‘);
                            modal.innerHTML = xhr.responseText;
                            obj._box.build( obj, modal );
                        } else {
                            obj._box.build( obj, null );
                        }
                    }
                };
                xhr.open(‘GET‘, obj.settings.url + ( !obj.settings.cache ? ‘?_=‘ + new Date().getTime() : ‘‘ ), true);
                xhr.setRequestHeader(‘X-Requested-With‘, ‘XMLHttpRequest‘);
                xhr.send(null);
            }
        },
        _close: function () {
            var obj = this;
            // Clean custombox.
            setTimeout(function () {
                // Remove classes.
                obj._removeClass( document.getElementsByTagName( ‘html‘ )[0], cb + ‘-hide-scrollbar‘ );
                // Reset properties scrollbar.
                document.getElementsByTagName( ‘body‘ )[0].style.marginRight = 0;
                // Remove modal.
                var modal = ( obj._isIE() ? document.querySelectorAll(‘.‘ + cb + ‘-modal‘)[0] : document.getElementsByClassName(cb + ‘-modal‘)[0] );
                obj._remove( modal );
                // Remove overlay.
                if ( obj.settings.overlay ) {
                    obj._remove( ( obj._isIE() ? document.querySelectorAll(‘.‘ + cb + ‘-overlay‘)[0] : document.getElementsByClassName(cb + ‘-overlay‘)[0] ) );
                }
                // Check if callback ‘close‘.
                if ( obj.settings.close && typeof obj.settings.close === ‘function‘ ) {
                    obj.settings.close( undefined !== arguments[0] ? arguments[0] : ‘‘ );
                } else if ( typeof modal !== ‘undefined‘ && modal.getAttribute(‘data-‘ + cb) !== null ) {
                    // Check if callback ‘close‘ when the method is public.
                    var onClose = modal.getAttribute(‘data-‘ + cb),
                        onCloseLaunch = new Function ( ‘onClose‘, ‘return ‘ + onClose )(onClose);
                    onCloseLaunch();
                }
                // Go to te last position scroll.
                window.top.scroll( 0, modal.getAttribute(‘data-‘ + cb + ‘-scroll‘) );
            }, obj.settings.speed );
            // Add class close for animation close.
            obj._addClass( ( obj._isIE() ? document.querySelectorAll(‘.‘ + cb + ‘-modal‘)[0] : document.getElementsByClassName(cb + ‘-modal‘)[0] ), ‘close‘ );
            // Remove the remaining classes.
            obj._removeClass( ( obj._isIE() ? document.querySelectorAll(‘.‘ + cb + ‘-modal‘)[0] : document.getElementsByClassName(cb + ‘-modal‘)[0] ), cb + ‘-show‘ );
            obj._removeClass( document.getElementsByTagName( ‘html‘ )[0], cb + ‘-perspective‘ );
        },
        _listeners: function () {
            var obj = this;
            // Listener overlay.
            if ( obj._isIE() ) {
                if ( typeof document.querySelectorAll(‘.‘ + cb + ‘-overlay‘)[0] !== ‘undefined‘ && obj.settings.overlayClose ) {
                    document.querySelectorAll(‘.‘ + cb + ‘-overlay‘)[0].attachEvent(‘onclick‘, function () {
                        obj._close();
                    });
                }
            } else {
                if ( typeof document.getElementsByClassName(cb + ‘-overlay‘)[0] !== ‘undefined‘ && obj.settings.overlayClose ) {
                    document.getElementsByClassName(cb + ‘-overlay‘)[0].addEventListener(‘click‘, function () {
                        obj._close();
                    }, false );
                }
            }
            // Listener on tab key esc.
            if ( obj.settings.escKey ) {
                document.onkeydown = function ( evt ) {
                    evt = evt || window.event;
                    if ( evt.keyCode === 27 ) {
                        obj._close();
                    }
                };
            }
            // Listener on element close.
            if ( obj.settings.eClose !== null && typeof obj.settings.eClose === ‘string‘ && obj.settings.eClose.charAt(0) === ‘#‘ || typeof obj.settings.eClose === ‘string‘ && obj.settings.eClose.charAt(0) === ‘.‘ && document.querySelector(obj.settings.eClose) ) {
                document.querySelector(obj.settings.eClose).addEventListener(‘click‘, function () {
                    obj._close();
                }, false );
            }
            // Check if callback ‘close‘.
            if ( obj.settings.close && typeof obj.settings.close === ‘function‘ ) {
                var store =  obj.settings.close;
                    var modal = ( obj._isIE() ? document.querySelectorAll(‘.‘ + cb + ‘-modal‘)[0] : document.getElementsByClassName(cb + ‘-modal‘)[0] );
                modal.setAttribute(‘data-‘ + cb, store);
            }
        },
        /*
         ----------------------------
         Utilities
         ----------------------------
         _extend()扩展对象,无深拷贝功能;
         _create(attr,styles,element)创建元素或为已存在的元素添加attr.id、attr.class,以及具体的样式;
         _hexToRgb(hex)将rgb代码值转化r、g、b值,16进制;
         _addClass(element,calss)添加样式;
         _removeClass(element,calss)移除样式;
         _hasClass(element,calss)有否样式;
         _remove(element)移除元素;
         _zIndex获取dom元素最大的z-index值;
         _isIE判断是否IE浏览器;
         _crossBrowser通过能力检测获取浏览器的transitionend或webkitTransitionEnd属性;
         _scrollbar(modal)调用_create方法为modal元素根据setting.position设置绝对定位、top、margin-top属性;
         */
        _extend: function () {
            for( var i = 1, arg = arguments.length; i < arg; i++ ) {
                for( var key in arguments[i] ) {
                    if( arguments[i].hasOwnProperty(key) ) {
                        arguments[0][key] = arguments[i][key];
                    }
                }
            }
            return arguments[0];
        },
        _create: function ( attr, styles, element ) {
            var div = ( element === undefined || element === null ? document.createElement(‘div‘) : element );
            // Compatibility ECMAScript 5 Objects and Properties.
            Object.keys = Object.keys || function( o ) {
                var result = [];
                for ( var name in o ) {
                    if ( o.hasOwnProperty(name) ) {
                        result.push(name);
                    }
                }
                return result;
            };
            if (  attr !== null && Object.keys(attr).length !== 0 ) {
                // Add the id.
                if ( attr.id !== null ) {
                    div.id = cb + ‘-‘ + attr.id;
                }
                // Add the class.
                if ( attr.eClass !== null ) {
                    this._addClass( div, attr.eClass );
                }
            }
            if ( styles !== null ) {
                // Loop with styles (obj).
                for ( var obj in styles ) {
                    if ( styles.hasOwnProperty(obj) ) {
                        // Insert browser dependent styles.
                        if ( this._isIE() ) {
                            var camelCase = obj.split(‘-‘);
                            if ( camelCase.length > 1 ) {
                                camelCase = camelCase[0] + camelCase[1].replace(/(?:^|\s)\w/g, function( match ) {
                                    return match.toUpperCase();
                                });
                            }
                            div.style[camelCase] = styles[obj];
                        } else {
                            div.style.setProperty( obj, styles[obj], null );
                        }
                        if ( ( obj.indexOf(‘transition‘) !== -1 || obj === ‘transform‘ !== -1 ) && !this._isIE() ) {
                            var prefix = [ ‘-webkit-‘, ‘-ms-‘];
                            // Insert prefix.
                            for ( var x = 0, pre = prefix.length; x < pre; x++ ) {
                                div.style.setProperty( prefix[x] + obj, styles[obj], null );
                            }
                        }
                    }
                }
            }
            return div;
        },
        _hexToRgb: function ( hex ) {
            // Expand shorthand form (e.g. "03F") to full form (e.g. "0033FF") - http://stackoverflow.com/questions/5623838/rgb-to-hex-and-hex-to-rgb
            var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
            hex = hex.replace(shorthandRegex, function(m, r, g, b) {
                return r + r + g + g + b + b;
            });
            var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
            return result ? {
                r: parseInt(result[1], 16),
                g: parseInt(result[2], 16),
                b: parseInt(result[3], 16)
            } : null;
        },
        _addClass: function ( element, eClass ) {
            if ( !this._hasClass( element, eClass ) ) {
                element.className = ( element.className.length && element.className !== ‘ ‘ ? element.className + ‘ ‘ + cb + ‘-‘ + eClass : cb + ‘-‘ + eClass );
            }
        },
        _removeClass: function ( element, eClass ) {
            if ( this._hasClass( element, eClass ) ) {
                var reg = new RegExp(‘(\\s|^)‘ + eClass + ‘(\\s|$)‘);
                element.className = element.className.replace(reg,‘ ‘);
            }
        },
        _hasClass: function ( element, eClass ) {
            return ( element !== undefined ? element.className.match(new RegExp(‘(\\s|^)‘ + eClass + ‘(\\s|$)‘)) : false );
        },
        _remove: function ( element ) {
            if ( element !== undefined ) {
                element.parentNode.removeChild(element);
            }
        },
        _zIndex: function () {
            var d = document,
                elems = d.getElementsByTagName(‘*‘),
                zIndexMax = 0;
            for ( var i = 0, etotal = elems.length; i < etotal; i++ ) {
                var zindex = d.defaultView.getComputedStyle(elems[i],null).getPropertyValue(‘z-index‘);
                if ( zindex > zIndexMax && zindex !== ‘auto‘ ) {
                    zIndexMax = zindex;
                }
            }
            return zIndexMax;
        },
        _isIE: function () {
            return navigator.appVersion.indexOf(‘MSIE 9.‘) != -1 || navigator.appVersion.indexOf(‘MSIE 8.‘) != -1;
        },
        _crossBrowser: function () {
            var el = document.createElement(‘fakeelement‘),
                transitions = {
                    transition:         ‘transitionend‘,
                    WebkitTransition:   ‘webkitTransitionEnd‘
                },
                transition;
            // Check transition.
            for( var t in transitions ) {
                if ( transitions.hasOwnProperty(t) && el.style[t] !== undefined ) {
                    transition =  transitions[t];
                }
            }
            return transition;
        },
        _scrollbar: function ( modal ) {
            var obj = this;
            // Go to te last position scroll.
            setTimeout( function () {
                window.scrollTo( 0, 0 );
            }, ( obj.settings.overlay ? obj.settings.overlaySpeed : 200 ) );
            var position = {
                ‘position‘:     ‘absolute‘
            };
            if ( obj.settings.position !== null && obj.settings.position.indexOf(‘top‘) !== -1 ) {
                position[‘top‘] = 0;
                position[‘margin-top‘] = ‘20px‘;
            }
            // Change property position
            obj._create( {}, position, modal );
        },
        /*
         ----------------------------
         Public methods
         ----------------------------
         */
        close: function () {
            this._close();
        }
    };
    // A really lightweight plugin wrapper around the constructor,
    // preventing against multiple instantiations with jQuery.
    $.fn[ cb ] = function ( options ) {
        var args = arguments,
            isElement = typeof HTMLElement === ‘object‘ ? options instanceof HTMLElement : options && typeof options === ‘object‘ && options !== null && options.nodeType === 1 && typeof options.nodeName === ‘string‘;
        if ( options === undefined || typeof options === ‘object‘ ) {
            if ( isElement ) {
                if ( navigator.appName === ‘Microsoft Internet Explorer‘ ) {
                    // Write a new regEx to find the version number.
                    var re = new RegExp(‘MSIE ([0-9]{1,}[.0-9]{0,})‘);
                    // If the regEx through the userAgent is not null.
                    if ( re.exec(navigator.userAgent) != null ) {
                        //Set the IE version
                        var version = parseInt(RegExp.$1);
                    }
                }
                if ( typeof version === ‘undefined‘ || version >= 10 ) {
                    // Check time to avoid double click.
                    if ( options.getAttribute(‘data-‘ + cb) !== null && parseInt(options.getAttribute(‘data-‘ + cb)) + 1 > Math.round( new Date().getTime() / 1000 ) ) {
                        return;
                    }
                    // Set time to avoid double click.
                    options.setAttribute(‘data-‘ + cb, Math.round( new Date().getTime() / 1000 ) );
                }
                $(options).each( function () {
                    $.data( this, cb, new Plugin( this, args[1] ) );
                });
            } else {
                new Plugin( null, args[0] );
            }
        } else if ( typeof options === ‘string‘ && options === ‘close‘ ) {
            $.data( this, cb, new Plugin( args[0], args[1] ) );
        }
    };
})( jQuery, window, document );
?
原文:http://schifred.iteye.com/blog/2298366