中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > JavaScript 拖放效果分析
Web標(biāo)準(zhǔn)在中國 回到列表 焦點圖片輪換第三季——iFocus
 JavaScript 拖放效果分析

作者:cloudgamer 時間: 2008-11-24 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 JavaScript 拖放效果分析 [1]
第 2 頁 JavaScript 拖放效果分析 [2]
第 3 頁 JavaScript 拖放效果分析 [3]
第 4 頁 JavaScript 拖放效果分析 [4]
第 5 頁 JavaScript 拖放效果分析 [5]

拖放鎖定

鎖定分三種,分別是:水平方向鎖定(LockX)、垂直方向鎖定(LockY)、完全鎖定(Lock)。
這個比較簡單,水平和垂直方向的鎖定只要在Move判斷是否鎖定再設(shè)置left和top就行,如果是完全鎖定就直接返回。

if(!this.LockX){ this.Drag.style.left = ...; }
if(!this.LockY){ this.Drag.style.top = ...; }

觸發(fā)對象

觸發(fā)對象是用來觸發(fā)拖放程序的。有的時候不需要整個拖放對象都用來觸發(fā),這時就需要觸發(fā)對象了。
使用了觸發(fā)對象后,進行移動的還是拖放對象,只是用觸發(fā)對象來觸發(fā)拖放(一般的使用是把觸發(fā)對象放到拖放對象里面)。

范圍限制

要設(shè)置范圍限制必須先把Limit設(shè)為true。范圍限制分兩種,分別是固定范圍和容器范圍限制,主要在Move程序中設(shè)置。
原理是當(dāng)比較的值超過范圍時,修正left和top要設(shè)置的值使拖放對象能保持在設(shè)置的范圍內(nèi)。

固定范圍限制

容器范圍限制就是指定上下左右的拖放范圍。
各個屬性的意思是:

  • 上(mxTop):top限制;
  • 下(mxBottom):top+offsetHeight限制;
  • 左(mxLeft):left限制;
  • 右(mxRight):left+offsetWidth限制。

如果范圍設(shè)置不正確,可能導(dǎo)致上下或左右同時超過范圍的情況,程序中有一個Repair程序用來修正范圍參數(shù)的。
Repair程序會在程序初始化和Start程序中執(zhí)行,在Repair程序中修正mxRight和mxBottom:

this.mxRight = Math.max(this.mxRight, this.mxLeft + this.Drag.offsetWidth);
this.mxBottom = Math.max(this.mxBottom, this.mxTop + this.Drag.offsetHeight);

其中mxLeft+offsetWidth和mxTop+offsetHeight分別是mxRight和mxBottom的最小范圍值。

根據(jù)范圍參數(shù)修正移動參數(shù):

iLeft = Math.max(Math.min(iLeft, mxRight - this.Drag.offsetWidth), mxLeft);
iTop = Math.max(Math.min(iTop, mxBottom - this.Drag.offsetHeight), mxTop);

對于左邊上邊要取更大的值,對于右邊下面就要取更小的值。

容器范圍限制

容器范圍限制的意思就是把范圍限制在一個容器_mxContainer內(nèi)。
要注意的是拖放對象必須包含在_mxContainer中,因為程序中是使用相對定位來設(shè)置容器范圍限制的(如果是在容器外就要用絕對定位,這樣處理就比較麻煩了),還有就是容器空間要比拖放對象大,這個就不用說明了吧。
原理跟固定范圍限制差不多,只是范圍參數(shù)是根據(jù)容器的屬性的設(shè)置的。

當(dāng)設(shè)置了容器,會自動把position設(shè)為relative來相對定位:

!this._mxContainer || CurrentStyle(this._mxContainer).position == "relative" || (this._mxContainer.style.position = "relative");

注意relative要在獲取offsetLeft和offsetTop即設(shè)置_x和_y之前設(shè)置,offset才能正確獲取值。

由于是相對定位,對于容器范圍來說范圍參數(shù)上下左右的值分別是0、clientHeight、0、clientWidth。

clientWidth和clientHeight是容器可視部分的寬度和高度(詳細參考這里)。
為了容器范圍能兼容固定范圍的參數(shù),程序中會獲取容器范圍和固定范圍中范圍更小的值:

mxLeft = Math.max(mxLeft, 0);
mxTop = Math.max(mxTop, 0);
mxRight = Math.min(mxRight, this._mxContainer.clientWidth);
mxBottom = Math.min(mxBottom, this._mxContainer.clientHeight);

注意如果在程序執(zhí)行之前設(shè)置過拖放對象的left和top而容器沒有設(shè)置relative,在自動設(shè)置relative時會發(fā)生移位現(xiàn)象,所以程序在初始化時就執(zhí)行一次Repair程序防止這種情況。因為offsetLeft和offsetTop要在設(shè)置relative之前獲取才能正確獲取值,所以在Start程序中Repair要在設(shè)置_x和_y之前執(zhí)行。

因為設(shè)置相對定位的關(guān)系,容器_mxContainer設(shè)置過后一般不要取消或修改,否則很容易造成移位異常。

出處:藍色理想
責(zé)任編輯:bluehearts

上一頁 JavaScript 拖放效果分析 [1] 下一頁 JavaScript 拖放效果分析 [3]

◎進入論壇網(wǎng)頁制作WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
焦點圖片輪換第三季——iFocus
不間斷滾動圖片Javascript特效講解
JavaScript的陷阱
用javascript修復(fù)瀏覽器中頭痛問題
Javascript利用閉包循環(huán)綁定事件
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/51個記錄/頁 轉(zhuǎn)到 頁 共5個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2