Tôi có một phần tử với một thuộc tính title
(ví dụ, một tooltip), được bọc trong một số container:Tooltips (title = "...") sẽ không hiển thị trong Firefox
<div id="foo">
<input type="text" title="A tooltip" />
</div>
và tôi đính kèm một "mousemove"
nghe sự kiện trên thùng và dừng sự kiện tuyên truyền:
document.getElementById('foo').addEventListener(
'mousemove',
function(e) { e.stopPropagation() },
false
)
sự kết hợp này dừng lại tuyên truyền của "mousemoves" trên thùng tại ngăn ngừa các tooltip hiển thị lên cho hộp văn bản bên trong, trong Firefox 2 và upwar ds. Tôi đã thử FF 2 [.0.0.20], 3 [.0.11] và phiên bản mới nhất 3.5 (Windows Server 2003, XP).
Như một bài tập nhanh chóng, Firefox người dùng có thể nhìn thấy lỗi này trong hành động bằng cách chạy logic tương đương sau như trên vào thanh địa chỉ của bạn:
javascript:void($('div.vote').mousemove(function(e){ e.stopPropagation() }))
Bây giờ di chuột lên bất kỳ số phiếu bầu lên, bỏ phiếu xuống, hoặc dấu sao (mục yêu thích) cho câu hỏi này. Chú giải công cụ không còn xuất hiện nữa. Một lần nữa, trong Firefox chỉ.
Có ai có giải pháp cho hành vi/lỗi này trong Firefox không? Có ai khác chứng kiến điều này không?
Cập nhật: Dường như Firefox sử dụng "di chuyển chuột ngừng" để kích hoạt chú giải công cụ trong chrome của trình duyệt (ví dụ: nút quay lại/tiến). Xem https://bugzilla.mozilla.org/show_bug.cgi?id=82953. Tuy nhiên tôi không thể biết điều này có ảnh hưởng đến DOM hay không.
Cập nhật: Có vẻ như Firefox 10 là phiên bản cuối cùng thể hiện hành vi này. Firefox 11.0 trở đi hiển thị chú giải công cụ bất kể sự kiện tuyên truyền.
Cập nhật: Firefox 33 (.1) không còn hiển thị hành vi này nữa.
"Chú giải công cụ cho nút" Bỏ phiếu "không còn xuất hiện khi bạn để chuột qua nó." Sai. –
Ditto, không xảy ra với tôi. – cgp
Điều đó đúng với tôi. –