热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

html添加tooltip(转载)

需求:给表单每个信息项添加一个帮助信息,当mouseover或focus时激活帮助信息效果:程序实现:*    2007-01-30 lisq custom tooltip    

需求:给表单每个信息项添加一个帮助信息,当mouseover或focus时激活帮助信息
效果:
程序实现:

/*
    2007-01-30 lisq custom tooltip
    use age:
    
    
    var config = new tooltip.config($('a0101'), '人员姓名', 400)
    var arrconfig = []
    arrconfig.push(config)
    var tootip = tooltip.init(arrconfig)
*/
event.observe(window, 'load', 
function(){
    
var div = document.createelement('div')
    div.id 
= 'tooltipid'
    
var divintrotopline = document.createelement('div')
    divintrotopline.id 
= 'divintrotopline'
    div.appendchild(divintrotopline)
    
    
var divintroarrow = document.createelement('div')
    divintroarrow.id 
= 'divintroarrow'
    divintrotopline.appendchild(divintroarrow)

    var divintrocontent = document.createelement('div')
    divintrocontent.id 
= 'divintrocontent'
    divintrocontent.innerhtml 
= 'hello world'
    div.appendchild(divintrocontent)
    
    tooltip.container 
= div
    tooltip.containercontent 
= divintrocontent
    document.body.appendchild(div)
    element.hide(div)
}, 
false)

var tooltip = {
    config : 
function(ele, tip, width){
        
this.ele = ele
        ele.config 
= this
        
this.tip = tip
        
this.width = width
    },
    init : 
function(arrconfig){
        
for(var i=0; i<arrconfig.length; i++){
            
var config = arrconfig[i]
            
if(!config || !config.ele || !config.tip)
                
continue
            config.ele.tip 
= config.tip
            config.ele.onmouseover 
= tooltip.mouseover
            config.ele.onmouseout 
= tooltip.mouseout
            config.ele.onfocus 
= tooltip.mouseover
            config.ele.onblur 
= tooltip.mouseout
        }
    },
    mouseover : 
function(){
        tooltip.container.style.width 
= this.config.width
        tooltip.containercontent.innerhtml 
= this.tip
        
var arr = position.positionedoffset(this)
        etooltip 
= $('tooltipid')
        etooltip.style.left 
= arr[0- 50
        etooltip.style.top 
= arr[1+ 21
        element.show(etooltip)
    },
    mouseout : 
function(){
        etooltip 
= $('tooltipid')
        element.hide(etooltip)
    }
}



调用:

var config = new tooltip.config(fieldinput, field.helpinfo, 150)
            tooltip.init([config])


第二种方法:
Javascript部分

//添加支持,如为某div则仅为该div中带有tooltip属性的元素提供支持。
function addtipsupport(e) {
 e.Onmouseover= showtip;
 e.Onmouseout= hidetip;
 e.Onmousemove= showtip;
}
//获得控件的绝对位置,返回左上角坐标
function getelepos(e){
 var t=e.offsettop;
 var l=e.offsetleft;
 while(e=e.offsetparent){
 t+=e.offsettop;
 l+=e.offsetleft;
 }
 
 return [l, t];
}
//显示tooltip
function showtip() {
 getelepos(event.srcelement);
 if(event.srcelement.tooltip && event.srcelement.tooltip!='') {
 altlayer.style.visibility='visible';
 var cord = getelepos(event.srcelement);
 altlayer.style.left=cord[0]+event.offsetx + 20;
 altlayer.style.top=cord[1]+event.offsety+25;
 altlayer.innerhtml=event.srcelement.tooltip;
 altlayer.style.zindex = event.srcelement.style.zindex + 1;
 }
 //else altlayer.style.visibility='hidden';
}
//隐藏tooltip
function hidetip() {
 altlayer.style.visibility = 'hidden';
}
//设置显示区域
addtipsupport(document.body); //此处的参数可换成其它,以局限在某容器内支持tooltip风格。
//////////tooltip结束//////////

html部分














推荐阅读
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • Android获取app应用程序大小的方法
    Android获取app应用程序大小的方法-Android对这种方法进行了封装,我们没有权限去调用这个方法,所以我们只能通过AIDL,然后利用Java的反射机制去调用系统级的方法。 ... [详细]
  • WPF之Binding初探
      初学wpf,经常被Binding搞晕,以下记录写Binding的基础。首先,盗用张图。这图形象的说明了Binding的机理。对于Binding,意思是数据绑定,基本用法是:1、 ... [详细]
  • html和js代码互转,html转html5
    本文目录一览:1、html网页跳转javascript代码实现 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了10分钟了解Android的事件分发相关的知识,希望对你有一定的参考价值。什么是事件分发?大家 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了常用#免费%代理IP库&整理*收藏——实时@更新(大概)相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 基于php常用正则表达式的整理汇总【PHP】
    后端开发|php教程php,常用正则表达式后端开发-php教程正则表达式3m互助直销系统源码,传感器ubuntu,在家无聊如何爬虫,phpuniquid,康华seo推广lzw如下所 ... [详细]
  • layui表格分页不生效怎么办
    web前端|Layui教程layuiweb前端-Layui教程小程序实例源码,ubuntuip切换,tomcat默认端改为80,爬虫完整源码,微信小程序php接口,seo专业培训班 ... [详细]
author-avatar
zoey小
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有