使用jquery为table的某一个td添加文字提示框,鼠标滑入出现,鼠标滑出消失
html
//因为tbody的内容是后来添加的,所以可以直接根据table来找到要加效果的td元素
//如果html中td元素不是动态添加的,则可以直接给td加class名或id名,获取后再操作就可以了
<tbody id="guding">
</tbody>
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内容填充到文字提示框中
$(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 = '<div class="tip" style="pointer-events:none;position:fixed;left:' + x + ';top:' + y + ';z-index:9000"><div class="box">'+$(this).text()+'</div><div class="arrow" style="margin-top:-5px"></div></div>'
$('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 */
<style type="text/css" media="screen">
.tip {
position: relative;
color: #fff;
text-align: center;
}
.box {
min-width: 400px;
height: 40px;
line-height: 40px;
background: #3c3636;
}
/* 向下箭头只是一个小方形,通过定位与旋转实现效果 */
.arrow {
width: 10px;
height: 10px;
position: absolute;
background: #3c3636;
left: 47%;
bottom: -5px;
transform: rotate(45deg);
-ms-transform: rotate(45deg); /* IE 9 */
-webkit-transform: rotate(45deg); /* Safari and Chrome */
-o-transform: rotate(45deg); /* Opera */
-moz-transform: rotate(45deg);
}
</style>