国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript中無法通過div.style.left獲取值的解決方法

2019-11-19 17:30:42
字體:
來源:轉載
供稿:網友

一、問題總結:

    樣式必須直接寫在元素內部才能通過div.style.left直接獲取屬性值(也就是必須是內聯樣式才行),定義在css中的樣式不能通過這種方式獲取。

   讓元素移動到200停止

setTimeout ( function () {    var div = document.getElementById("div4");  //var left = parseInt(div.style.left) + 5;  var left = div.offsetLeft + 5;    div.style.left = left + "px";  if (left < 200) {    setTimeout( arguments.callee, 50);  }  }, 50);

二、關于offsetLeft和left的區別(關于offsetLeft:https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLElement/offsetLeft

   1.定義了position:relative或absolute屬性的元素才有left屬性,元素都有offsetLeft屬性。

   2.元素內聯樣式中設置了left,才能通過div.style.left獲取;offsetLeft直接通過div.offsetLeft獲取。

   3.left可讀可寫,獲取到的是字符串;offsetLeft只讀,獲取到的是數字。

  相同點:定位方式一樣,如果父元素設置了定位元素(position設置為relative或absolute),則相對于定位元素定位,否則就是相對于根元素定位。

三、案例:

    HTMLElement.offsetParent 是一個只讀屬性,返回一個指向最近的(closest,指包含層級上的最近)包含該元素的定位元素。如果沒有定位的元素,則 offsetParent 為最近 的 table 元素對象或根元素(標準模式下為 html;quirks 模式下為 body)。當元素的 style.display 設置為 "none" 時,offsetParent 返回 null。offsetParent 很有用,因為 offsetTop 和 offsetLeft 都是相對于其內邊距邊界的。

    下面的span的父元素沒有設置定位元素,所以該元素的offsetParent為根元素,此時的offsetTop相對于根元素定位。

<div style="width: 300px; border-color:blue; border-style:solid; border-width:1;"> <span>Short span. </span> <span id="long">Long span that wraps withing this div.</span> </div><div id="box" style="position: absolute; border-color: red; border-width: 1; border-style: solid; z-index: 10"></div><script> var box = document.getElementById("box"); var long = document.getElementById("long"); // // long.offsetLeft這個值就是span的offsetLeft. // span是個行內元素,它沒有沒absolute定位,但還是默認offserParent就是父元素,而不是根 // box.style.left = long.offsetLeft + document.body.scrollLeft + "px"; box.style.top = long.offsetTop + document.body.scrollTop + "px"; box.style.width = long.offsetWidth + "px"; box.style.height = long.offsetHeight + "px";</script>

如果給long的父元素添加一個定位屬性,結果如下:

 四、總結:

   javascript中通過offsetLeft(offsetTop)方法獲取元素偏移值很方便,得到的是數值;改變元素的偏移值使用style.left(top、right、bottom),通過style.left獲取的是一個字符串的值,如果要通過style.left來改變元素位置,先要通過parseInt將獲取到的當前left值轉化為數值。

以上所述是小編給大家介紹的JavaScript中無法通過div.style.left獲取值的解決方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 碌曲县| 南汇区| 涡阳县| 沧州市| 三门县| 安塞县| 墨竹工卡县| 横山县| 和静县| 永兴县| 赤城县| 公主岭市| 民丰县| 崇左市| 新密市| 留坝县| 天峻县| 武邑县| 铁岭县| 洛川县| 嘉祥县| 和平县| 社旗县| 中阳县| 霞浦县| 普陀区| 冕宁县| 大港区| 五台县| 隆德县| 临澧县| 连州市| 遂川县| 昆山市| 托里县| 调兵山市| 沙坪坝区| 原平市| 安庆市| 青浦区| 滨州市|