javascript基于对象的弹出框封装
先睹为快,移动端:戳这里,打开页面后点击投票查看效果。PC端测试直接切换body的overflow属性:hidden和auto一样可以,比下面相对简化,又有人说这样偶尔不行。。如果你知道优缺点欢迎给出。。。。
说明:1、DOM元素必须,2、弹出框样式:必须,3、弹出框逻辑必须,4、如何使用,需要的时候直接调用:promptObj.init(msg),msg:弹出框的提示信息,不传默认是:請問你想幹嘛?
封装很简单,关键就是弹出框弹出后如何阻止页面继续滚动,经过测试目前没问题,关于指出问题。缺点:暴露在全局的对象
1、必须的DOM元素,放在BODY尾部
<!-- 自定义alert框 -->
<div id="prompt_box">
<div class="prompt_mask">
<p>友情提示:</p>
<h2 id="prompt_title" class="prompt_title"></h2>
<span id="prompt_btn">確 認</span>
</div>
</div>
2、DOM元素的样式表
/*
* @Author: wangjianfei
* @Date: 2017-05-26 17:24:39
* @Last Modified by: wangjianfei
* @Last Modified time: 2017-05-26 19:33:57
*/
*{
margin:;
padding:;
list-style: none;
border:;
box-sizing: border-box;
outline:;
-webkit-tap-highlight-color: transparent;
}
#prompt_box{
position: fixed;
width: 100%;
height: 100%;
left:;
top:;
bottom:;
background: rgba(0, 0, 0, .5);
display: none;
z-index:;
}
.prompt_title{
text-align: center;
color: #565CB2;
margin-top: .5rem;
}
.prompt_mask p{
width: 100%;
height: 1rem;
color: #fff;
line-height: 1rem;
background: #565CB2;
padding-left: .3rem;
font-size: .4rem;
}
.prompt_mask{
width: 7.4rem;
height: 4.2rem;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background: #fff;
border-radius: .1rem;
overflow: hidden;
} #prompt_btn{
display: block;
background: #565CB2;
color: #fff;
width: 1.5rem;
height: .8rem;
line-height: .8rem;
text-align: center;
margin: 0 auto;
margin-top: .8rem;
border-radius: .1rem;
font-size: .3rem;
cursor: pointer;
}
3、弹出的逻辑
/*
* @Author: wangjianfei
* @Date: 2017-05-26 18:08:36
* @Last Modified by: wangjianfei
* @Last Modified time: 2017-05-27 10:22:26
*/ 'use strict';
var promptObj={
// 1、弹出框ID
promptBox:null,
// 2、提示信息的元素ID
infoItem:null,
// 3、确认按钮ID
promptBtn:null,
// 4、提示信息具体内容,没传就默认是:請問你想幹嘛?
tipsMsg:null,
// 5、是PC还是手机:true为PC,false为手机端,用于阻止弹出框弹出后页面是否可以滚动
isPC:true,
// 6、初始化对象
init:function(msg){
//1、 指定元素
this.promptBox=document.getElementById("prompt_box");
this.infoItem=document.getElementById("prompt_title");
this.promptBtn=document.getElementById("prompt_btn");
// 2、是否是PC
this.platform();
// 3、显示弹出框 promptBtn
this.showPrompt(msg);
},
// 7、设备判断
platform:function(){
var _this=this;
var userAgentInfo = navigator.userAgent;
var Agents = ["Android", "iPhone",
"SymbianOS", "Windows Phone",
"iPad", "iPod"];
for (var v = 0; v < Agents.length; v++) {
if (userAgentInfo.indexOf(Agents[v]) > 0) {
_this.isPC= false;
break;
}
}
},
// 8、隐藏弹出框
hidePrompt:function(){
promptObj.promptBox.style.display="none";
},
// 9、显示弹出框,并禁止页面继续
showPrompt:function(msg){
var _this=this;
// console.log(_this.isPC);
// 提示信息
_this.tipsMsg=msg||"請問你想幹嘛?";
_this.infoItem.innerHTML=_this.tipsMsg;
_this.promptBox.style.display="block";
_this.promptBtn.addEventListener("click", _this.hidePrompt);
// 2、如果是PC端
if(_this.isPC){
// PC端弹出框弹出后阻止页面滚动
var top=-1;
var scrollTop = document.documentElement.scrollTop||window.pageYOffset||document.body.scrollTop;
_this.promptBox.addEventListener("mouseenter", function(){
top=scrollTop;
// console.log(top);
});
_this.promptBox.addEventListener("mouseleave", function(){
top=-1;
});
window.addEventListener("scroll",function(event){
event.preventDefault();
// console.log(scrollTop);
if(top!==-1){
document.body.scrollTop=scrollTop;
window.pageYOffset=scrollTop;
document.documentElement.scrollTop=scrollTop;
// console.log(scrollTop);
}
});
// 3、如果是移动端
}else{
// 移动端阻止弹出层弹出时候页面的滚动
_this.promptBox.addEventListener("touchmove", function(event){
// 阻止彈出後頁面的滚动
event.preventDefault();
});
}
}
}
// promptObj.init();
javascript基于对象的弹出框封装的更多相关文章
- JavaScript 实现简单的 弹出框关闭框
JavaScript 实现简单的 弹出框关闭框 知识点: 1.javaScript 添加HTML标签 2.javaScript 添加HTML标签属性 3.javaScript 追加元素 代码献上: & ...
- .NET MVC 学习笔记(四)— 基于Bootstarp自定义弹出框
.NET MVC 学习笔记(四)—— 基于Bootstarp自定义弹出框 转载自:https://www.cnblogs.com/nele/p/5327380.html (function ($) { ...
- JS弹出框插件zDialog再次封装
zDialog插件网址:http://www.jq22.com/jquery-info2426 再次封装zDialog的代码: (function ($) { $.extend({ iDialog: ...
- JavaScript 弹出框
JavaScript 有三种类型的弹出框:警告框.确认框和提示框. 警告框 如果要确保信息传递给用户,通常会使用警告框. 当警告框弹出时,用户将需要单击“确定”来继续. 语法 window.alert ...
- ASP.NET中的几种弹出框提示
B/S不像C/S那样一个MessageBox就可以弹出提示框,不过可以通过js的“Alert”来弹出消息,或者通过一些变种的js方法.下面我给大家介绍几种,希望大家喜欢. 四种弹出框代码: prote ...
- 弹出框layer的使用封装
layer弹出框官方网址:http://layer.layui.com/ layer常用方法的封装:layerTool.jsp layer.config({ extend: 'extend/layer ...
- 基于HTML5 Canvas 实现弹出框
用户鼠标移入时,有弹出框出现,这样的需求很常见.这在处理HTML元素实现时简单,但是如果是对HTML5 Canvas 构成的图形进行处理,这种方法不再适用,因为Canvas使用的是另外一套机制,无论在 ...
- vue封装公用弹出框方法,实现点击出现操作弹出框
vue封装公用弹出框方法,实现点击出现操作弹出框 如上图所示,这次要实现一个点击出现操作弹框的效果:并将这个功能封装成一个函数,便于在项目的多个地方使用. 具体思路是: 封装一个组件,组件保护一个插槽 ...
- 自定义弹出框基于zepto 记得引入zepto
html <!DOCTYPE html> <html> <meta charset="utf-8"> <title></tit ...
随机推荐
- Python学习第一章
1.Python保留字即是关键字,我们不可以把他们当作任何标识符名称. python的标准库提供了一个keyword模板,可以输出当前版本的关键字: >>>import keywor ...
- shell 命令 zip unzip
工作当中,经常要用到zip压缩. zip 将文件夹打包: 如文件夹名 xxx zip -r xxx.zip xxx unzip unzip -o xxx.zip -o 覆盖原有的文件夹 查询更多参数: ...
- Latex 自定义命令:用于一些特殊单词的显示
\usepackage{xspace} \newcommand{\ie}{{\emph{i.e.}},\xspace} \newcommand{\viz}{{\emph{viz.}},\xspace} ...
- 基于ε-NFA的正则表达式引擎
正则表达式几乎每个程序员都会用到,对于这么常见的一个语言,有没有想过怎么去实现一个呢?乍一想,也许觉得困难,实际上实现一个正则表达式的引擎并没有想像中的复杂,<编译原理>一书中有一章专门讲 ...
- 每日分享!canvas的使用~
今天大概的说下canvas的使用~ canvas是H5新增的一个元素,可以用来在canvas上绘制一些图形! 如何使用canvas呢? 首先我们用canvas绘制一条直线! <!DO ...
- Java面试集合(二)
前言 大家好,给大家带来Java面试集合(二)的概述,希望你们喜欢 二 1.请问线程有哪些状态? 新建状态(New) 就绪状态(Runnable) 运行状态(Running) 阻塞状态(Blocked ...
- koa-static与react-create-app搭配的路径
概述 前端路由与后端路由的结合一直是一个难题.koa-static这个中间件能够把静态资源"搬到"后端路由上面去,react-create-app在不解构的情况下只会把资源打包到b ...
- 用HTML5 video标签插入视频,在谷歌浏览器上播放视频时,右下角显示的下载按钮怎么去掉
使用H5的video标签可以直接插入视频,一般在浏览器效果如下图显示: 但有时在谷歌浏览器上显示,会遇到右下角有下载按钮.如果项目要求去掉这个下载按钮,怎么办呢?如下图显示: 分析: 经本人测试,是谷 ...
- HW2017笔试编程题
一.写一个转换字符串的函数 1.题目描述 将输入字符串中下标为偶数的字符连成一个新的字符串输出,需要注意两点: (1)如果输入字符串的长度超过20,则转换失败,返回“ERROR!”字符串: (2)输入 ...
- Linux学习笔记之十一————Linux常用服务器构建之ssh和scp
一.ssh 1.ssh介绍 SSH为Secure Shell的缩写,由 IETF 的网络工作小组(Network Working Group)所制定:SSH 为建立在应用层和传输层基础上的安全协议. ...