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 ...
随机推荐
- veri HDL modeisim仿真:test bench文件编写
预编译指令: verilog HDL预编译指令是以" ' "字符开头,而且不需要以";"结尾. 作用:指示在编译verilog hdl源代码前,需要执行哪些操作 ...
- shell脚本基础教程
一.什么是shell: shell解释:引用别人的话说:“Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁.Shell 既是一种命令语言,又是一种程序设计语言.” 简而言之, ...
- 关于ASP.NET MVC 中JsonResult返回的日期值问题
最近开始用MVC做项目,在使用 JsonResult返回数据的时候,日期被反射成了/Date 1233455这种格式,遍查网上都是在客户端使用JS来处理这个问题的,这样的话,就需要在每一个涉及到日期的 ...
- Weex是如何让JS调用产生原生UIView的?
从官方的Demo,我们知道,要在客户端显示Weex页面,是通过WXSDKInstance的实例实现的.我们先来看看这个类里面都有什么: @interface WXSDKInstance : NSObj ...
- python 使用 sorted 对 列表嵌套元组的数据进行排序
在开发的过程可能会遇到这么一个需求,存在一个列表嵌套元组的数据: data = [(1, 'a'),(2, 'b'),(5, 'c'),(3, 'd'),(4, 'e')] 需要将这个列表按照元组的第 ...
- Ngon 是啥
https://www.gamefromscratch.com/post/2011/07/11/So-whats-an-ngon-anyways.aspx 在 blender 里面 Add 一个 Cy ...
- 抽取JDBC工具类并增删改查
抽取工具类: package demo; /* * 工具类 */ import java.sql.Connection; import java.sql.DriverManager; import j ...
- Java学习笔记52(网络编程:UDP协议案例)
InetAddress类: 表示互联网中的IP地址,示例: package demo; import java.net.InetAddress; import java.net.UnknownHost ...
- 从 moment -> nodejs -> sequelize -> postgres,你都得设置好时区
背景 最近在做报表统计,因为 sequelize 的时区配置没加导致了统计数字对不上的问题. 问:大家都知道时区,但是你清楚 UTC 和 GMT 的区别吗? 答:UTC 是我们现在用的时间标准,GMT ...
- 手把手教你如何用eclipse搭建前端开发环境
3.创建静态web工程 打开eclipse,选择file,new project 或者 new other...,选择web项中的static web project ,next. 输入你的项目名,如 ...