热门标签 | 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部分














推荐阅读
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • html和js代码互转,html转html5
    本文目录一览:1、html网页跳转javascript代码实现 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 如何在HTML中获取鼠标的当前位置
    本文介绍了在HTML中获取鼠标当前位置的三种方法,分别是相对于屏幕的位置、相对于窗口的位置以及考虑了页面滚动因素的位置。通过这些方法可以准确获取鼠标的坐标信息。 ... [详细]
  • 用Vue实现的Demo商品管理效果图及实现代码
    本文介绍了一个使用Vue实现的Demo商品管理的效果图及实现代码。 ... [详细]
  • layui表格分页不生效怎么办
    web前端|Layui教程layuiweb前端-Layui教程小程序实例源码,ubuntuip切换,tomcat默认端改为80,爬虫完整源码,微信小程序php接口,seo专业培训班 ... [详细]
  • 开发笔记:UEditor调用上传图片上传文件等模块
    1、引入ue相关文件,写好初始代码为了更好的封装整一个单独的插件,这里我们要做到示例化ue后隐藏网页中的编辑窗口,并移除焦点。 ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 本文介绍了互联网思维中的三个段子,涵盖了餐饮行业、淘品牌和创业企业的案例。通过这些案例,探讨了互联网思维的九大分类和十九条法则。其中包括雕爷牛腩餐厅的成功经验,三只松鼠淘品牌的包装策略以及一家创业企业的销售额增长情况。这些案例展示了互联网思维在不同领域的应用和成功之道。 ... [详细]
  • yii2 绑定框架事件
    后端开发|php教程php,yii2后端开发-php教程我想要添加自定义代码处理yii2框架的Application::EVENT_BEFORE_REQUEST时触发的事件,但是不 ... [详细]
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社区 版权所有