JavaScript Title、alt提示(Tips)实现源码解读


Posted in Javascript onDecember 12, 2010

而对于图片标签img也有一个alt属性可以起到类似的作用。但很显然这种提示框太单调了,为此有人用JavaScript实现了漂亮的提示框效果,这种效果常用在WEB游戏中,其中下图的网易邮箱与迅雷影视页面就用到这种效果,虽然彼此实现效果有些差异,但整体实现思路是不变的。为了方便大家了解实现的细节,以方便定制自己想要的效果,我上网找了一段不错的源码,并对其进行了详细的注释,希望对大家有帮助。

JavaScript Title、alt提示(Tips)实现源码解读
JavaScript Title、alt提示(Tips)实现源码解读

含注释代码:
/*********************************************** 
一个JavaScript Title、alt提示(Tips)源码解读 
代码注释:唐国辉 
作者博客:http://webflash.cnblogs.com 
***********************************************/ 
//定义getElementById快捷方式 
function $(obj) 
{ 
if(typeof(obj)=='object') 
{ 
return obj; 
} 
else 
{ 
return document.getElementById(obj); 
} 
} 
//定义document.write快捷方式,代替复杂的DOM操作 
function $P(str) 
{ 
document.write(str); 
} 
//脚本错误屏蔽 
window.onerror=function () 
{ 
return true; 
}; 
/* 
定义变量: 
pltsPop(提示内容文字,来自对象的alt或title属性,不包含HTML) 
toolTip(提示内容DOM对象,即后面定义的content变量) 
pltsPoptop(上方提示标题DOM对象) 
pltsPopbot(下方提示标题DOM对象) 
topLeft(左上角提示标题DOM对象) 
botLeft(左下方提示标题DOM对象) 
topRight(右上角提示标题DOM对象) 
botRight(右下方提示标题DOM对象) 
*/ 
var pltsPop,toolTip,pltsPoptop,pltsPopbot,topLeft,botLeft,topRight,botRight; 
//设置提示窗口相对提示对象的位置偏移量 
var pltsoffsetX=10; 
var pltsoffsetY=15; 
var pltsTitle=""; 
//创建一个绝对定位的隐藏图层 
$P('<div id=\"pltsTipLayer\" style="display:none; position:absolute; z-index:10001" mce_style="display:none; position:absolute; z-index:10001"></div>'); 
//把刚创建的层对象赋值给一个变量,此语句一定要出现在层创建之后 
var pltsTipLayer=$('pltsTipLayer'); 
//定义鼠标移到对象上时处理函数,主要提取alt或title属性值,并初始化提示框HTML及样式 
function PltsMouseOver(ev) 
{ 
//兼容不同浏览器的事件和对象获取 
var Event=window.event||ev; 
var o=Event.srcElement||Event.target; 
//如果对象alt属性存在并且不等于空,就把它的值存到dypop属性,并清空当前alt内容 
if(o.alt!=null&&o.alt!="") 
{ 
o.dypop=o.alt; 
o.alt=""; 
} 
//如上,对具有title属性的对象作同样的判断和处理,清空title属性值是让对象默认的提示效果失效 
if(o.title!=null&&o.title!="") 
{ 
o.dypop=o.title; 
o.title=""; 
} 
pltsPop=o.dypop; 
if(pltsPop!=null&&pltsPop!=""&&typeof(pltsPop)!="undefined") 
{ 
//把上面创建的提示层显示出来,暂时移到左边很远,虽然显示但用户看不到 
pltsTipLayer.style.left=-1000; 
pltsTipLayer.style.display=''; 
/* 
格式化提示信息,把其中的\n换成<br/>,比如像下面这样定义title值,显示出来会是作者和性别各一行,因为Tom和Sex之间有\n: 
<div title="Author:Tom 
Sex:male">Article title...</div> 
*/ 
var Msg=pltsPop.replace(/\n/g,"<br/>"); 
Msg=Msg.replace(/\0x13/g,"<br/>"); 
//定义正则表达式检查提示内容是否含有类似这样的内容“{提示标题}”,而且{}和{{}是排除在处的,如果没有就默认用“简介”作为提示标题 
var re=/\{(.[^\{]*)\}/ig; 
if(!re.test(Msg)) 
{ 
pltsTitle="<label style="\" mce_style="\""color:#000\">简介</label>"; 
} 
else 
{ 
re=/\{(.[^\{]*)\}(.*)/ig; 
//提取{}中的内容 
pltsTitle=Msg.replace(re,"$1")+" "; 
//把{内容},包括{}在内的内容替换为空,得到最终提示正文的内容 
re=/\{(.[^\{]*)\}/ig; 
Msg=Msg.replace(re,""); 
} 
//定义提示框内容Html与Style,并把获得的相关内容放到对应变量中 
var content="<dl id=\"toolTip\" style="\" mce_style="\""-moz-opacity:0.85;opacity:0.85;FILTER:alpha(opacity=85);padding:2px;background:#fff;\"><dd id=\"pltsPoptop\" class=\"toolTipTitle\" style="\" mce_style="\""line-height:20px;\"><p id=\"topLeft\" class=\"left\"><b><label style="\" mce_style="\""color:#ffffff\">?</label>"+pltsTitle+"</b></p><p id=\"topRight\" class=\"right\" style="\" mce_style="\""display:none\"><b>"+pltsTitle+"<label style="\" mce_style="\""color:#ffffff\">?</label ></b></p></dd><dd class=\"toolTipMsg\">"+Msg+"</dd><dd id=\"pltsPopbot\" style="\" mce_style="\""display:none\" class=\"toolTipTitle\"><p id=\"botLeft\" class=\"left\"><b><label style="\" mce_style="\""color:#ffffff\">?</label >"+pltsTitle+"</b></p><p id=\"botRight\" class=\"right\" style="\" mce_style="\""display:none\"><b>"+pltsTitle+"<label style="\" mce_style="\""color:#ffffff\">?</label></b></p></dd></dl>"; 
pltsTipLayer.innerHTML=content; 
toolTip=$("toolTip"); 
pltsPoptop=$("pltsPoptop"); 
pltsPopbot=$("pltsPopbot"); 
topLeft=$("topLeft"); 
botLeft=$("botLeft"); 
topRight=$("topRight"); 
botRight=$("botRight"); 
//设置提示框宽度,它的大小是提示框自身大小和浏览器可见窗口大小一半两者中的最小值,即在浏览器窗口小过提示框本身宽度后,会自动调整提示框大小到一个新的宽度 
toolTip.style.width=Math.min(pltsTipLayer.clientWidth,document.documentElement.clientWidth/2.2)+"px"; 
} 
else 
{ 
pltsTipLayer.innerHTML=''; 
pltsTipLayer.style.display='none'; 
} 
} 
//定义鼠标在对象上移动时处理函数,每移动一像素触发一次事件 
function PltsMouseMove(ev) 
{ 
if(pltsTipLayer.innerHTML=='') 
return true; 
var Event=window.event||ev; 
//获取光标当前X、Y坐标 
var MouseX=Event.clientX; 
var MouseY=Event.clientY; 
//获取提示框宽高度 
var popHeight=pltsTipLayer.clientHeight; 
var popWidth=pltsTipLayer.clientWidth; 
//如果当前光标Y坐标+提示框Y轴偏移量+提示框高度>当前窗口可见高度,一般处理窗口中下方要提示的对象,比如页脚有一个链接需要提示时就会是这种情况,此时考虑使用下方标题 
if(MouseY+pltsoffsetY+popHeight>document.documentElement.clientHeight) 
{ 
//提示框显示在要提示对象上方时需要一个额外值popTopAdjust作为提示框最终定位的依据 
popTopAdjust=-popHeight-pltsoffsetY*1.5; 
pltsPoptop.style.display="none"; 
pltsPopbot.style.display=""; 
} 
else 
{ 
popTopAdjust=0; 
pltsPoptop.style.display=""; 
pltsPopbot.style.display="none"; 
} 
//判断使用左标题还是右标题 
if(MouseX+pltsoffsetX+popWidth>document.documentElement.clientWidth) 
{ 
popLeftAdjust=-popWidth-pltsoffsetX*2; 
topLeft.style.display="none"; 
botLeft.style.display="none"; 
//下面两个标题都显示,其实最终看到的只有一个位置上的标题,因为topRight是pltsPoptop的子元素,如果pltsPoptop不显示,topRight显示也是看不到的,botLeft同理 
topRight.style.display=""; 
botRight.style.display=""; 
} 
else 
{ 
popLeftAdjust=0; 
topLeft.style.display=""; 
botLeft.style.display=""; 
topRight.style.display="none"; 
botRight.style.display="none"; 
} 
//把综合处理得到的提示框最终位置值设置到对象,其中scrollTop是网页被卷去的高度,因为style.top是相对整个文档的而不是浏览器窗口,所以要算上滚动隐藏的高度,scrollLeft同理 
pltsTipLayer.style.left=MouseX+pltsoffsetX+document.documentElement.scrollLeft+popLeftAdjust+"px"; 
pltsTipLayer.style.top=MouseY+pltsoffsetY+document.documentElement.scrollTop+popTopAdjust+"px"; 
return true; 
} 
//定义事件绑定函数 
function PltsInit() 
{ 
document.onmouseover=PltsMouseOver; 
document.onmousemove=PltsMouseMove; 
} 
//调用事件绑定函数 
PltsInit();

调用方法:把上面的代码存到一个外部独立的JS文件中,然后在网页页面中包含这个JS文件,最后给需要提示的对象加上title属性,图片可以加alt属性就可以了。举例:<a href="#" title="{完整标题}完整标题文字">缩写标题</a> 或 <img src="#" alt="图片提示" />

相关链接:
1、http://www.cnblogs.com/czh-liyu/archive/2007/12/30/1021146.html
2、http://boxover.swazz.org
3、http://blog.csdn.net/lanmao100/archive/2008/10/31/3191767.aspx

Javascript 相关文章推荐
基于jQuery的仿flash的广告轮播代码
Nov 04 Javascript
Bootstrap组件系列之福利篇几款好用的组件(推荐二)
Jul 12 Javascript
AngularJS入门教程之过滤器详解
Aug 19 Javascript
jquery移除了live()、die(),新版事件绑定on()、off()的方法
Oct 26 Javascript
浅析js的模块化编写 require.js
Dec 07 Javascript
Async Validator 异步验证使用说明
Jul 03 Javascript
Vue-Router模式和钩子的用法
Feb 28 Javascript
Vue中使用vee-validate表单验证的方法
May 09 Javascript
微信小程序自定义toast的实现代码
Nov 16 Javascript
Vue使用mixin分发组件的可复用功能
Sep 01 Javascript
vue动态渲染svg、添加点击事件的实现
Mar 13 Javascript
js之ajax文件上传
May 13 Javascript
js中的值类型和引用类型小结 文字说明与实例
Dec 12 #Javascript
JS俄罗斯方块,包含完整的设计理念
Dec 11 #Javascript
用于节点操作的API,颠覆原生操作HTML DOM节点的API
Dec 11 #Javascript
JavaScript下利用fso判断文件是否存在的代码
Dec 11 #Javascript
jQuery ul标签下拉菜单演示代码
Dec 11 #Javascript
基于jquery的修改当前TAB显示标题的代码
Dec 11 #Javascript
Wordpress ThickBox 添加“查看原图”效果代码
Dec 11 #Javascript
You might like
PHP Class&amp;Object -- PHP 自排序二叉树的深入解析
2013/06/25 PHP
php curl抓取网页的介绍和推广及使用CURL抓取淘宝页面集成方法
2015/11/30 PHP
PHP实现的通过参数生成MYSQL语句类完整实例
2016/04/11 PHP
laravel框架之数据库查出来的对象实现转化为数组
2019/10/23 PHP
Web版彷 Visual Studio 2003 颜色选择器
2007/01/09 Javascript
原生js实现给指定元素的后面追加内容
2013/04/10 Javascript
window.location.href中url中数据量太大时的解决方法
2013/12/23 Javascript
在javascript中实现函数数组的方法
2013/12/25 Javascript
jquery操作复选框(checkbox)的12个小技巧总结
2014/02/04 Javascript
jQuery中removeAttr()方法用法实例
2015/01/05 Javascript
每天一篇javascript学习小结(基础知识)
2015/11/10 Javascript
vue-ajax小封装实例
2017/09/18 Javascript
jQuery实现的回车触发按钮事件功能示例
2018/03/25 jQuery
解决Nodejs全局安装模块后找不到命令的问题
2018/05/15 NodeJs
轻量级富文本编辑器wangEditor结合vue使用方法示例
2018/10/10 Javascript
使用url_helper简化Python中Django框架的url配置教程
2015/05/30 Python
Python判断直线和矩形是否相交的方法
2015/07/14 Python
Python 字典与字符串的互转实例
2017/01/13 Python
Python 爬虫之超链接 url中含有中文出错及解决办法
2017/08/03 Python
使用Python读取安卓手机的屏幕分辨率方法
2018/03/31 Python
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
对pandas处理json数据的方法详解
2019/02/08 Python
python获取微信企业号打卡数据并生成windows计划任务
2019/04/30 Python
解决yum对python依赖版本问题
2019/07/05 Python
详解Django定时任务模块设计与实践
2019/07/24 Python
python3 pathlib库Path类方法总结
2019/12/26 Python
pytorch 多分类问题,计算百分比操作
2020/07/09 Python
新西兰领先的鞋类和靴子网上商城:Merchant 1948
2017/09/08 全球购物
Strawberrynet草莓网新加坡站:护肤、彩妆、香水及美发产品
2018/08/31 全球购物
物业保安主管岗位职责
2013/12/25 职场文书
国际经济贸易专业自荐信
2014/06/13 职场文书
家属慰问信
2015/02/14 职场文书
教师党员自我评价范文
2015/03/04 职场文书
幼儿园新学期开学寄语
2015/05/27 职场文书
2015秋季开学典礼致辞
2015/07/16 职场文书
canvas实现贪食蛇的实践
2022/02/15 Javascript