javascript中各種寬高以及event對象的總結(jié)

參考文章:https://segmentfault.com/a/1190000002545307

1、對原生的元素屬性的理解

     clientWidth = padding*2 + width
     clientHeight = padding*2 + height
     clientLeft = border
     clientTop = border

     offsetParent 指的是當(dāng)前元素離自己最近的具有定位的父級元素
     offsetWidth = (padding+border)*2 + width
     offsetHeight = (padding+border)*2 + height
     offsetLeft = 距離offsetParent左邊距離
     offsetTop = 距離offsetParent上邊距離

     scrollTop          獲取元素中的內(nèi)容 超出 元素上邊界的那部分高度
     scrollLeft          獲取元素中的內(nèi)容 超出 元素左邊界的那部分寬度
     scrollHeight      獲取元素的完整高度(不包括border)
     scrollWidth       獲取元素的完整寬度(不包括border)

除了scrollTop和scrollLeft可讀可寫些侍,其余的只讀
以上返回的值均不帶單位

2仰禀、obj.style.* 屬性
它只能獲取該元素的行內(nèi)樣式,而并不能獲取到該元素最終計算好的樣式
使用obj.currentStyle(IE)和getComputerStyle(IE之外的其他瀏覽器)
返回的值為帶單位的字符串

function getStyle(obj, attr){
  if(obj.currentStyle){
    return obj.currentStyle[attr];
  }else{
    return getComputedStyle(obj,false)[attr];
  }
}

3、Event對象
在js中,對于元素的運動操作通常都會涉及到event對象,而event對象也存在很多位置屬性驹止,且由于瀏覽器兼容性問題會導(dǎo)致這些屬性間相互混淆!

  • clientX和clientY观蜗,這對屬性是當(dāng)事件后臊恋,鼠標(biāo)點擊位置相對于瀏覽器(可視區(qū))的坐標(biāo),從瀏覽器的左上角(0墓捻,0)開始計算鼠標(biāo)點擊位置距離其左上角的位置抖仅。

  • screenX和screenY是事件發(fā)生時鼠標(biāo)相對于屏幕的坐標(biāo),以設(shè)備屏幕的左上角為原點砖第,事件發(fā)生時鼠標(biāo)點擊的地方即為改點的screenX和screenY值撤卢。相對于屏幕,而又是瀏覽器梧兼。

  • offsetX和offsetY放吩,這對屬性是當(dāng)事件時,鼠標(biāo)點擊位置相對于該事件源(不包含border)的位置羽杰,即點擊該div屎慢,以該div為原點來計算鼠標(biāo)點擊位置的坐標(biāo)(注:firefox不支持該屬性瞭稼,firefox中與此屬性對應(yīng)的概念是忽洛,event.layerX和event.layerY腻惠,所以要使用該屬性時,需要做兼容性處理)

var divX = event.offsetX || event.layerX;
  • pageX和pageY欲虚,該屬性是事件發(fā)生時鼠標(biāo)點擊位置相對于頁面的位置集灌,通常瀏覽器窗口還沒有出現(xiàn)滾動條時,該屬性和clientX和clientY是等價的复哆,但是當(dāng)瀏覽器出現(xiàn)滾動條時欣喧,pageX通常會大于clientX,因為頁面還存在被卷起來的部分的寬度和高度梯找。即pageX和pageY是相對于整個頁面的位置
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末唆阿,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子锈锤,更是在濱河造成了極大的恐慌驯鳖,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件久免,死亡現(xiàn)場離奇詭異浅辙,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)阎姥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進(jìn)店門记舆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人呼巴,你說我怎么就攤上這事泽腮。” “怎么了衣赶?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵诊赊,是天一觀的道長。 經(jīng)常有香客問我屑埋,道長豪筝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任摘能,我火速辦了婚禮续崖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘团搞。我一直安慰自己严望,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布逻恐。 她就那樣靜靜地躺著像吻,像睡著了一般峻黍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上拨匆,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天姆涩,我揣著相機(jī)與錄音,去河邊找鬼惭每。 笑死骨饿,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的台腥。 我是一名探鬼主播宏赘,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼黎侈!你這毒婦竟也來了察署?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤峻汉,失蹤者是張志新(化名)和其女友劉穎贴汪,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體俱济,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡嘶是,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蛛碌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片聂喇。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖蔚携,靈堂內(nèi)的尸體忽然破棺而出希太,到底是詐尸還是另有隱情,我是刑警寧澤酝蜒,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布誊辉,位于F島的核電站,受9級特大地震影響亡脑,放射性物質(zhì)發(fā)生泄漏堕澄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一霉咨、第九天 我趴在偏房一處隱蔽的房頂上張望蛙紫。 院中可真熱鬧,春花似錦途戒、人聲如沸坑傅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽唁毒。三九已至蒜茴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間浆西,已是汗流浹背粉私。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留室谚,地道東北人毡鉴。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像秒赤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子憎瘸,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容