js 自定义类Android吐司提示框
(function(){
var mouseX = 0;
var mouseY = 0;
//定义一个全局toaslist用来存在新建的吐司
var toastLsit = [];
window.Toast = function(content,duration,positon)
{
return new Toast(content,duration,positon);
}
function Toast(content,duration,positon)
{
//显示的内容
this.content = content || "注意";
this.duration = duration || 500;
this.ToastDom = null;
this.ToastDomOpacity = 100;
this.toastTimer = false;
this.toastTimeOut = false;
this.mouseX = mouseX;
this.mouseY = mouseY;
this.zindex = 999;
this.position = positon || "mouse";
this.initToastDom();
this.bindEvent();
this.hiddenToast();
toastLsit.push(this);
}
//绑定事件,缓慢变透明,然后移除,如果鼠标hover透明度又恢复
Toast.prototype.bindEvent = function(){
var _this = this;
this.ToastDom.onselectstart = function(){return false;}
this.ToastDom.onmouseover = function(){
_this.zindex = 999;
_this.ToastDomOpacity = 100;
_this.ToastDom.style.filter = 'alpha(opacity:'+ _this.ToastDomOpacity +')';
_this.ToastDom.style.opacity = _this.ToastDomOpacity/100;
_this.ToastDom.style.zIndex = _this.zIndex;
clearInterval(_this.toastTimer);
clearTimeout(_this.toastTimeOut);
}
this.ToastDom.onmouseout = function(){
_this.hiddenToast();
}
};
Toast.prototype.hiddenToast = function(){
clearTimeout(this.toastTimeOut);
var _this = this;
_this.toastTimeOut = setTimeout(function(){
_this.toastTimer = setInterval(
function(){
_this.ToastDomOpacity --;
_this.zIndex --;
_this.ToastDom.style.zIndex = _this.zIndex;
_this.ToastDom.style.filter = 'alpha(opacity:'+ _this.ToastDomOpacity +')';
_this.ToastDom.style.opacity = _this.ToastDomOpacity/100;
if(_this.ToastDomOpacity <= 0)
{
clearInterval(_this.toastTimer);
document.body.removeChild(_this.ToastDom);
toastLsit.shift();
}
},10);
},800);
}
//初始化布局
Toast.prototype.initToastDom = function(){
//新建一个DIV
this.ToastDom = document.createElement("div");
this.ToastDom.innerHTML = this.content;
//然后给这个元素布局
//这个元素的位置应该是 浏览器的最底部 居中的位置,并且在所有元素的顶部 且不能影响其他元素的布局
this.ToastDom.style.position = "fixed";
//背景色
this.ToastDom .style.backgroundColor = "#000";
this.ToastDom .style.color = "#fff";
this.ToastDom .style.minWidth = "200px";
this.ToastDom .style.textAlign = "center";
this.ToastDom .style.padding = "10px";
this.ToastDom .style.borderRadius = "5px";
this.ToastDom .style.cursor = "pointer";
//只有先上树之后才有具体的宽高
document.body.appendChild(this.ToastDom);
if(this.position == "mouse")
{
this.ToastDom.style.top = this.mouseY + 10 + "px";
this.ToastDom.style.left = this.mouseX + 10 + "px";
}
else if(this.position == "top")
{
this.ToastDom.style.top = "25px";
this.ToastDom.style.left = "50%";
this.ToastDom.style.marginLeft = -(getStyle(this.ToastDom,"width") / 2) +"px";
}
else
{
this.ToastDom.style.bottom = "25px";
this.ToastDom.style.left = "50%";
this.ToastDom.style.marginLeft = -(getStyle(this.ToastDom,"width") / 2) +"px";
}
}
function getStyle(obj,name)
{
if(obj.currentStyle)
{
return parseFloat(obj.currentStyle[name]);
}
else
{
return parseFloat(getComputedStyle(obj)[name]);
}
}
//监听鼠标移动事件
document.onmousemove = function(e){
e = e || window.event;
mouseX = e.pageX;
mouseY = e.pageY;
}
})();
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>模拟手机吐司</title>
<script type="text/javascript" src="js/Toast.js" ></script>
</head>
<body> <input type="text" />
<button>吐司</button> <div style="height:1500px;"> </div>
<script> document.getElementsByTagName("button")[0].onclick = function(){
Toast(document.getElementsByTagName("input")[0].value); } </script>
</body>
</html>
js 自定义类Android吐司提示框的更多相关文章
- Android消息提示框Toast
Android消息提示框Toast Toast是Android中一种简易的消息提示框.和Dialog不一样的是,Toast是没有焦点的,toast提示框不能被用户点击,而且Toast显示的时间有限,t ...
- JS使用cookie实现DIV提示框只显示一次的方法
本文实例讲述了JS使用cookie实现DIV提示框只显示一次的方法.分享给大家供大家参考,具体如下: 这里运用JavaScript的cookie技术,控制网页上的提示DIV只显示一次,也就是当用户是第 ...
- 通过自定义window来实现提示框效果
#import <UIKit/UIKit.h>#import <Foundation/Foundation.h> @interface ZMStatuBarHud : NSOb ...
- JS学习笔记 -- 定时器,提示框的应用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js实现弹出的提示框只弹出一次
<script type="text/javascript"> var ua = navigator.userAgent.toLowerCase(); if (/iph ...
- Android 退出提示框 代码
转自:http://hi.baidu.com/ittdt/item/d932cf37f486f886c3cf29ea new AlertDialog.Builder(MainEngine.contex ...
- js自定义类和对象及继承
1.工厂方式 <script type="text/javascript"> function createObject(name){ var p = new Obje ...
- js关于移入移出延迟提示框效果处理
html部分 <div id="div1">我是导航君</div> <div id="div2" style="disp ...
- js 自定义类
将近20年前,Javascript诞生的时候,只是一种简单的网页脚本语言.如果你忘了填写用户名,它就跳出一个警告. 如今,它变得几乎无所不能,从前端到后端,有着各种匪夷所思的用途.程序员用它完成越来越 ...
随机推荐
- Postman接口调试神器
Postman起初源自googleBrowser的一款插件,现已经有单独软件,当然之前的插件也存在 它主要是用于接口的的调试 接口请求的流程 一.GET请求 GET请求:点击Params,输入参数及 ...
- HDU 4010 Query on The Trees(动态树)
题意 给定一棵 \(n\) 个节点的树,每个点有点权.完成 \(m\) 个操作,操作四两种,连接 \((x,y)\) :提 \(x\) 为根,并断 \(y\) 与它的父节点:增加路径 \((x,y)\ ...
- 拦截导弹nlogn解法
题目 题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国 ...
- 转 flowcanvas
http://blog.sina.com.cn/s/blog_5fb40ceb0102wveq.html Unity 强大的可视化编程插件,Flowcanvas + Nodecanvas 组合(深度修 ...
- (免费电影)苹果手机合并.ts视频
代码教程:https://mp.weixin.qq.com/s/6Oo8TOruePUxotC11zp0ag
- [python](windows)分布式进程问题:pickle模块不能序列化lambda函数
运行错误:_pickle.PicklingError: Can't pickle <function <lambda> at 0x000002BAAEF12F28>: attr ...
- vue-update-表单形式复写方法上传图片
handleSave() { const formData = new FormData(); /* eslint-disable */ for (let key in this.dataInfo) ...
- Anaconda 创建环境
2019-03-25 17:10:51 Anaconda 给不同的项目创建不同的环境真的非常重要,最近在使用flask的时候在base环境中安装flask-bootstrap,竟然将我原本的py3.7 ...
- DP爬台阶问题
1. 初级爬台阶 - 求最短步数 LC - 70 一次可以迈1-2个台阶,因此最短步数与前两个台阶有关. Initial state: 第一阶:1步 : 第二阶:1步 deduction functi ...
- 『TensorFlow』滑动平均
滑动平均会为目标变量维护一个影子变量,影子变量不影响原变量的更新维护,但是在测试或者实际预测过程中(非训练时),使用影子变量代替原变量. 1.滑动平均求解对象初始化 ema = tf.train.Ex ...