jquery文字提示框

//如果html中td元素不是动态添加的,则可以直接给td加class名或id名,获取后再操作就可以了

js

// 创建文字提示框并赋值属性与样式

// 外层div

var tip = document.createElement(‘div’)

$(tip).attr(‘class’, ‘tip’)

$(tip).css(‘pointer-events’, ‘none’)

// 文字框

var box = document.createElement(‘div’)

$(box).attr(‘class’, ‘box’)

// 向下箭头

var arrow = document.createElement(‘div’)

$(arrow).attr(‘class’, ‘arrow’)

$(tip).append(box)

$(tip).append(arrow)

//通过find()方法找到td

var tdList = $(‘#guding’).find(‘td:nth-child(3)’)

// 鼠标滑入事件

$(tdList).on(‘mouseenter’, function(ev) {

// 获取event元素,即获取事件状态(元素,键盘,鼠标等的状态)

var oEvent = ev || event

// 将td内容填充到文字提示框中

( b o x ) . h t m l ( (box).html( (box).html((this).text())

// 根据鼠标在屏幕中的位置,设置文字提示框的位置

$(tip).css(‘left’, oEvent.clietX - 50 + ‘px’)

$(tip).css(‘top’, oEvent.clientY - 50+ ‘px’)

// 此处一开始用position定位,但position:absolute是根据设置了relative的父元素进行定位的,所以当屏幕大小发生变化时(如果存在滚动内容,absolute是根据父元素进行定位),位置也会发生变化

// 浏览器窗口可视区域的X,Y坐标(窗口坐标),可视区域不包括工具栏和滚动条,而position:fixed属性也是设置元素在当前可视窗口的位置

$(tip).css(‘position’, ‘fixed’)

$(tip).css(‘z-index’, ‘9000’)

// 将文字提示框添加到body中

$(‘body’).append(tip)

// 也可直接使用字符串拼接省略上面“创建文字框步骤”

var appendHtml = ‘

’+$(this).text()+‘

$(‘body’).append(appendHtml)

// 因为如果直接使用clienX与clientY属性来定位元素,鼠标位置就是元素的左上角,上边使用各减50px来进行位置调整,但如果文字过长就会导致位置还不是特别精准,箭头处不会处在要进行文字提示的元素正上方位置,所以此处应该减去的是文字提示框的长度/2,这样箭头位置几乎处于元素最上方

var w = $(‘.box’).outerWidth()

var x1 = oEvent.clientX - w / 2 + ‘px’

$(‘.tip’).css({

‘position’: ‘fixed’,

‘left’: x1,

‘top’: y,

‘z-index’: 9000,

})

})

// 鼠标滑出事件

// 在此使用移出子节点方法remove()而不是使用"display: none",因为创建太多节点也不移除只是隐藏的话会影响性能

$(tdList).on(‘mouseleave’, function(ev, a) {

$(‘body’).remove(tip)

})

css

/* 在这里一开始给了.tip和.box宽度为200最大400,但是当宽度超过200时还是不能显示完全,又不能不给宽度,所以在这里只需要给.box最小宽度min-width */

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值