.獲取元素在文檔上的坐標
function DocuemntHtmlPageXY (elem) { var rect = elem.getBoundingClientRect(); var scrollTop = window.scrollTop || (document.documentElement && document.documentElement.scrollTop) || document.body.scrollTop || 0; var scrollLeft = window.scrollLeft || (document.documentElement && document.documentElement.scrollLeft) || document.body.scrollLeft || 0; var html = document.documentElement || document.getElementsByTagName_r('html')[0]; //修復ie6 7 下的瀏覽器邊框也被算在 boundingClientRect 內的 bug var deviation = html.getBoundingClientRect(); //修復 ie8 返回 -2 的 bug deviation = { //FF 不允許修改返回的對象 left: deviation.left < 0 ? 0 : deviation.left, top: deviation.top < 0 ? 0 : deviation.top }; return { left: rect.left + scrollLeft - deviation.left, top: rect.top + scrollTop - deviation.top }; }
2.舉例如下:
前端開發中,有時我們需要模擬點擊頁面上的某個位置,比如自動化測試或者模擬用戶操作。今天,我將一步步帶大家實現這個功能,讓大家能夠輕松理解并應用。
簡單來說,x 和 y 坐標就是頁面上的一個點的位置。x 代表水平方向,y 代表垂直方向。我們通過這兩個數值可以準確地定位到頁面上的某個點,然后在這個點上模擬一次點擊,就像用戶用鼠標點擊一樣。
我們可以通過 document.elementFromPoint 方法來實現。這個方法會返回指定坐標上的元素,然后我們對這個元素調用 click 方法,就能模擬一次點擊。
基本實現步驟
假設我們有以下 HTML 結構:
<div>
hello world
</div>
我們希望點擊這個 div 元素,首先可以寫以下代碼:
// 監聽所有點擊事件,并在控制臺打印被點擊的元素
document.addEventListener('click', (e) => {
console.log(e.target);
});
// 定義我們要點擊的坐標
const x = 10;
const y = 10;
// 獲取指定坐標上的元素,并觸發點擊事件
document.elementFromPoint(x, y).click();
詳細解釋:
除了直接調用 click 方法,我們還可以使用 MouseEvent 構造函數來模擬更復雜的點擊事件,比如包括點擊的位置、是否可以取消等屬性。
// 監聽所有點擊事件,并在控制臺打印被點擊的元素
document.addEventListener('click', (e) => {
console.log(e.target);
});
// 定義坐標
const x = 10;
const y = 10;
// 創建一個點擊事件
const click = (x, y) => {
const ev = new MouseEvent('click', {
'view': window,
'bubbles': true,
'cancelable': true,
'screenX': x,
'screenY': y
});
// 獲取指定坐標上的元素
const el = document.elementFromPoint(x, y);
// 分發點擊事件
el.dispatchEvent(ev);
};
// 調用點擊函數
click(x, y);
詳細解釋:
通過本文的講解,我們了解了如何在 JavaScript 中通過 x, y 坐標來模擬點擊事件。無論是直接調用 click 方法,還是使用 MouseEvent 構造函數,都能實現這一功能。希望大家在日常開發中能用到這個技巧,提升工作效率。
如果你覺得本文有幫助,不妨點贊收藏,也可以分享給更多需要的小伙伴。
近在做一個微信端的應用,其中有一個功能是這樣的功能:不管怎么移動百度地圖都能獲取到屏幕中心點的坐標。這種功能在ios端和android端通過一些邏輯計算很容易就實現了,但是在web端想要動態的獲取地圖屏幕中心點的坐標,通過計算就不是那么容易實現的了。通過翻找百度地圖手冊收發現百度地圖在js接口中提供的有一個方法,下面只列出關鍵性的代碼:
var map = new BMap.Map("allmap");
map.centerAndZoom(new BMap.Point(116.4035,39.915), 14);
var bs = map.getBounds(); //獲取可視區域
var bssw = bs.getSouthWest(); //可視區域左下角
var bsne = bs.getNorthEast(); //可視區域右上角
//alert("當前地圖可視范圍是:" + bssw.lng + "," + bssw.lat + "到" + bsne.lng + "," + bsne.lat);
var pt = bs.getCenter(); //獲取地圖中心點
//根據中心點坐標添加彈跳動畫marker
var point = new BMap.Point(pt.lng, pt.lat);
var marker = new BMap.Marker(point); // 創建標注
map.addOverlay(marker);// 將標注添加到地圖中
marker.setAnimation(BMAP_ANIMATION_BOUNCE);
*請認真填寫需求信息,我們會在24小時內與您取得聯系。