先睹为快,移动端:戳这里,打开页面后点击投票查看效果。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基于对象的弹出框封装的更多相关文章

  1. JavaScript 实现简单的 弹出框关闭框

    JavaScript 实现简单的 弹出框关闭框 知识点: 1.javaScript 添加HTML标签 2.javaScript 添加HTML标签属性 3.javaScript 追加元素 代码献上: & ...

  2. .NET MVC 学习笔记(四)— 基于Bootstarp自定义弹出框

    .NET MVC 学习笔记(四)—— 基于Bootstarp自定义弹出框 转载自:https://www.cnblogs.com/nele/p/5327380.html (function ($) { ...

  3. JS弹出框插件zDialog再次封装

    zDialog插件网址:http://www.jq22.com/jquery-info2426 再次封装zDialog的代码: (function ($) { $.extend({ iDialog: ...

  4. JavaScript 弹出框

    JavaScript 有三种类型的弹出框:警告框.确认框和提示框. 警告框 如果要确保信息传递给用户,通常会使用警告框. 当警告框弹出时,用户将需要单击“确定”来继续. 语法 window.alert ...

  5. ASP.NET中的几种弹出框提示

    B/S不像C/S那样一个MessageBox就可以弹出提示框,不过可以通过js的“Alert”来弹出消息,或者通过一些变种的js方法.下面我给大家介绍几种,希望大家喜欢. 四种弹出框代码: prote ...

  6. 弹出框layer的使用封装

    layer弹出框官方网址:http://layer.layui.com/ layer常用方法的封装:layerTool.jsp layer.config({ extend: 'extend/layer ...

  7. 基于HTML5 Canvas 实现弹出框

    用户鼠标移入时,有弹出框出现,这样的需求很常见.这在处理HTML元素实现时简单,但是如果是对HTML5 Canvas 构成的图形进行处理,这种方法不再适用,因为Canvas使用的是另外一套机制,无论在 ...

  8. vue封装公用弹出框方法,实现点击出现操作弹出框

    vue封装公用弹出框方法,实现点击出现操作弹出框 如上图所示,这次要实现一个点击出现操作弹框的效果:并将这个功能封装成一个函数,便于在项目的多个地方使用. 具体思路是: 封装一个组件,组件保护一个插槽 ...

  9. 自定义弹出框基于zepto 记得引入zepto

    html <!DOCTYPE html> <html> <meta charset="utf-8"> <title></tit ...

随机推荐

  1. noip第19课资料

  2. Alpha冲刺 (2/10)

    Part.1 开篇 队名:彳艮彳亍团队 组长博客:戳我进入 作业博客:班级博客本次作业的链接 Part.2 成员汇报 组员1(组长)柯奇豪 过去两天完成了哪些任务 学习并配置了ssm框架(用于前后端交 ...

  3. 18.数组(一)之认识java数组

    数组是一个简单的复合数据类型,它是一组有序数据的集合,它当中的每一个数据都具有相同的数据类型,我们通过数组名再加上一个不会越界的下标值来唯一确定数组中的元素. 还有就是,数组是一个特殊的对象. 不管在 ...

  4. 为什么需要micro-service构建平台

    最近一直在做micro-service的开发平台建设.由于这是一个实验项目,目前所有工作都得靠自己操刀. 今天在总结用python开发一个web service时,偶有所得,这让我建设micro-se ...

  5. PHPCMS9.6.0最新版SQL注入和前台GETSHELL漏洞分析 (实验新课)

    PHPCMS9.6.0最新版中,由于/modules/attachment/attachments.php的过滤函数的缺陷导致了可以绕过它的过滤机制形成SQL注入漏洞,可导致数据库中数据泄漏. 而且在 ...

  6. 4.json解析

    格式 {"name":"zhangsan", "age":18, "books":[{"name": ...

  7. AndroidStudio项目制作倒计时模块

    前言 大家好,给大家带来AndroidStudio项目制作倒计时模块的概述,希望你们喜欢 项目难度 AndroidStudio项目制作倒计时模块的难度,不是很大,就是主要用了Timer和TimerTa ...

  8. Zabbix-3-自定义脚本获取数据

    通过在agent中加入脚本,来获取数据,生成图形

  9. RSA实现JS前端加密,PHP后端解密

    web前端,用户注册与登录,不能直接以明文形式提交用户密码,容易被截获,这时就引入RSA. 前端加密 需引入4个JS扩展文件,jsbn.js.prng4.js.rng.js和rsa.js. <h ...

  10. 脚手架vue-cli系列四:vue-cli工程webpack的基本用法

    webpack的打包依赖于它的一个重要配置文件webpack.config.js,在这个配置文件中就可以指定所有在源代码编译过程中的工作了,就一个配置就可以与冗长的Gruntfile或者Gulpfil ...