麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

jQuery position() 函數詳解以及jQuery中position函數的應用

2024-05-06 16:26:19
字體:
來源:轉載
供稿:網友
position()函數用于返回當前匹配元素相對于其被定位的祖輩元素的偏移,也就是相對于被定位的祖輩元素的坐標。該函數只對可見元素有效,通過本文給大家介紹jQuery position() 函數詳解以及jQuery中position函數的應用,感興趣的朋友一起學習吧
 

position()函數用于返回當前匹配元素相對于其被定位的祖輩元素的偏移,也就是相對于被定位的祖輩元素的坐標。該函數只對可見元素有效。

所謂"被定位的元素",就是元素的CSS position屬性值為absolute、relative或fixed(只要不是默認的static即可)。

該函數返回一個坐標對象,該對象有一個left屬性和top屬性。屬性值均為數字,它們都以像素(px)為單位。

與offset()不同的是:position()返回的是相對于被定位的祖輩元素的坐標,offset()返回的是相對于當前文檔的坐標。此外,position()函數無法用于設置操作。如果當前元素的祖輩元素全部都是默認定位(static),那么該函數返回的偏移位置與offset()函數相同。

該函數屬于jQuery對象(實例)。

語法

jQuery 1.2 新增該函數。

jQueryObject.position( )

返回值

position()函數的返回值為Object類型,返回一個相對于離它最近的"被定位的"祖輩元素的偏移坐標對象,該對象具有left和top屬性。

如果當前jQuery對象匹配多個元素,返回坐標時,position()函數只以其中第一個匹配的元素為準。如果沒有匹配的元素,則返回undefined。

position()中的坐標參考系是以被定位的祖輩元素的左上角為原點(0,0),向右為正,向下為正。

示例&說明

以下面這段HTML代碼為例:

<br><br><p id="n1"><span id="n2">專注于編程開發技術分享</span></p>

以下jQuery示例代碼用于演示position()函數和offset()函數的用法:

var $n2 = $("#n2");// 輸出n2的偏移坐標var pos = $n2.position();document.writeln( "n2的position()偏移坐標:(" + pos.left + ", " + pos.top + ")" ); // n2的position()偏移坐標:(8, 60)var coord = $n2.offset();document.writeln( "n2的offset()的偏移坐標:(" + coord.left + ", " + coord.top + ")" ); // n2的offset()的偏移坐標:(8, 60)

從上述jQuery的運行結果可知,position()并不是獲取相對于其父元素的偏移位置。如果n2的祖輩元素全部為默認定位,則position()返回的偏移位置和offset()函數一致。

下面,我們將上述HTML代碼中的n1加上相對定位(relative):

<br><br><p id="n1" style="position: relative;" ><span id="n2">專注于編程開發技術分享</span></p>

然后,我們重新執行上述jQuery代碼,可以看到以下結果:

var $n2 = $("#n2");// 輸出n2的偏移坐標var pos = $n2.position();document.writeln( "n2的position()偏移坐標:(" + pos.left + ", " + pos.top + ")" ); // n2的position()偏移坐標:(0, 0)var coord = $n2.offset();document.writeln( "n2的offset()的偏移坐標:(" + coord.left + ", " + coord.top + ")" ); // n2的offset()的偏移坐標:(8, 60)

 

此時,在n2的祖輩元素中,n1是離n2最近的定位的祖輩元素(這里是relative,absolute、fixed也是如此),因此position()返回n2相對于n1的偏移位置。

.jQuery中position函數的應用(居中,超出屏幕處理等)

jQuery提供了一個Position函數,可以很方便的對Html元素進行定位,簡單的使用方法如下:

$(".daygrid").click(function(event){  clickedGrid = $(this);  $(".modal").modal("show");  $(".modal").position({    of:clickedGrid,    offset:" ",    collision:"fit"  });});

上面是一個很常用的用法,注冊一個click時間,然后當有點擊事件發生時,獲取到被點擊的元素,然后將對話框用position方法顯示至界面中。

position函數接受一個options對象,參數有很多

of:表示要放置在那個對象上,也可以傳遞click的event對象

my與at:這兩個比較不容易理解,其實也就是參照物和被參照物,my參數表示用什么位置來做參照而at表示參照目標的那個位置。值范圍為”left center right top bottom”的任意一個或兩個。舉個例子:my:”top left”,at:”left buttom”,這樣配置表示將要被定為的元素的左上角放置在目標元素的左下角。

collision:表示如何處理碰撞,值范圍為:”flip fit none”三選一。flip的官方英文說明看不是很懂,實際測試的效果是,如果超出了預期范圍(如window)則會嘗試將元素放置到目標區域的相反位置。fit是適應,也就是會將元素完整的放置在預期范圍內,而不會讓元素溢出。而none則是不做任何碰撞處理。

offset表示依靠my、at、of對齊元素后再進行多少距離的偏移,例如設置為”100 100″表示移至目標位置后再向下和右偏移100px

常見的使用就是彈出對話框的位置,為了讓對話框在鼠標點擊的位置顯示,則可以將click傳的event對象傳遞給of參數,并且為了保證對話框在窗口范圍內,可以將collision設置為fit。最后再根據實際需求來設置對齊參數my和at,并且用offset進行偏移微調。一個將彈出對話框設置在窗口中央的例子:

$("#myDialog").position({  my: "center",  at: "center",  of: window,  collision:"fit"});

以上內容是小編給大家分享的jQuery position() 函數詳解以及jQuery中position函數的應用的全部敘述,希望大家喜歡。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 国产成人精品免费视频大全最热 | 午夜视频国产 | 日韩欧美电影一区二区三区 | 国产99久久久久久免费看农村 | 黄色免费在线网址 | 亚州综合图片 | 日韩av片在线播放 | 亚洲午夜免费电影 | 欧美成人精品不卡视频在线观看 | 国产午夜亚洲精品 | 亚洲精品午夜视频 | 日韩伦理电影免费观看 | www.成人在线 | 国产一级午夜 | 免费看毛片网站 | 欧美一级毛片大片免费播放 | 国产精品久久久久久久久久久久久久久久 | 91精品国产777在线观看 | 九九精品在线观看 | av日韩一区二区 | 国产一国产一级毛片视频在线 | h视频免费在线 | 国产午夜探花 | av影院在线播放 | 在线免费观看毛片视频 | 操碰| 中国字幕av | 欧美日韩国产成人在线 | 午夜精品久久久久久久久久久久久蜜桃 | 精品一区二区免费视频视频 | 欧美成人午夜一区二区三区 | 嗯~啊~用力~高h | 深夜小视频在线观看 | 国产精品久久久久久一区二区三区 | 黄色免费在线电影 | 久久久av亚洲男天堂 | 黄色三级三级三级 | 激情小说激情图片激情电影 | 日本特级a一片免费观看 | 亚洲国产网站 | 日本不卡一区二区在线观看 |