詳細介紹在Bootstrap中為Modal新增拖曳功能
本篇主要介紹了詳解為Bootstrap Modal添加拖曳的方法,現在分享給大家,也給大家做個參考。
【相關影片推薦:Bootstrap教學】
網路上有許多給Bootstrap Modal添加拖曳實現,但是許多程式碼看起來都比較複雜感覺封裝性可能也不太好,有的甚至使用了jquery ui的拖曳功能,這些都不是我想要的,其實我在給Bootstrap Modal添加拖曳功能的事情已經是2017年春節的時候了,彈指一揮間一年就過去了。 2017年春節的時候,由於之前專案有同事使用layer來做前端,但是對於我這種略懂js前端的後端開發來說,讓我引入layer和layui的一整套東西是艱難的,曾經大致的瀏覽過layui的一些元件,發現元件功能不是很完備,可以預見的是稍微複雜點的專案後期就會帶來很多坑。因此當時就使用了bootstrap去作為前端的css框架,也大量使用modal這樣的元件來做彈出視窗。
步驟(基於3.3.4或更高的3.x版本):
#1.開啟bootstrap.js原始碼找到modal元件程式碼區塊,在Modal .DEFAULTS程式碼區塊下加入拖曳程式碼實作。
Modal.DEFAULTS = { backdrop: true, keyboard: true, show: true } //新加入的拖拽 Modal.prototype.draggable = function () { var $ele = this.$element; var mouseOffset; var $modalDialog = $ele.find(".modal-dialog"); var dialogOffset; $ele.find(".modal-header").on('mousedown', function (event) { $(this).addClass({cursor: 'move'}); $('body').addClass('select'); dialogOffset = $modalDialog.offset(); mouseOffset = { top: event.pageY - dialogOffset.top, left: event.pageX - dialogOffset.left }; $('body').on("mousemove", function (event) { var left = event.pageX - mouseOffset.left; var top = event.pageY - mouseOffset.top; if (left < 10) { left = 0; } else if (left > $(window).width() - $modalDialog.width()) { left = $(window).width() - $modalDialog.width(); } if (top < 10) { top = 0; } else if (top > $(window).height() - $modalDialog.height()) { top = $(window).height() - $modalDialog.height(); } $modalDialog.offset({ top: top, left: left }); }); }); $(document).on("mouseup mouseleave", function () { $('body').off("mousemove"); }); }
2. 在modal的show方法中添加調用draggable方法
Modal.prototype.show = function (_relatedTarget) { var that = this var e = $.Event('show.bs.modal', {relatedTarget: _relatedTarget}) this.$element.trigger(e) if (this.isShown || e.isDefaultPrevented()) return this.isShown = true //调用draggable()增加拖拽 this.draggable() this.checkScrollbar() this.setScrollbar() this.$body.addClass('modal-open') this.escape() this.resize() //......省略 }
完成上面的操作後直接引入剛剛修改的源碼js在頁面就已經能夠很好的支持拖曳了,而且整個拖曳是在可視窗口範圍內,不會超出邊界。
注意事項:完成上面的源碼修改後最好將bootstrap的源碼壓縮打包,不熟悉自動構建的可以放到開放的網站壓縮,熟悉自動化構建的最好使用gulp、webpack這樣的前端自動化工具來打包壓縮原始碼減少網頁載入過程中佔用頻寬。當然也建議將檔案命名為bootstrap-draggable.min.js類似的名稱,方便一目了然的猜到這檔案與原始檔案有何不同。除此之外你也可以直接下載bootstrap3.x版本的原始碼,然後修改裡面的modal.js,然後使用它自己grunt建置來重新打包。
問題引深:bootstrap 4.0 的版本原始碼和3.x的版本相比modal元件的修改並不很大,同樣可以採取上面的方式。包括讓modal居中也可修改原始碼來完成。
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
pace.js和NProgress .js如何使用載入進度外掛程式(詳細教學)
在jQuery中有關NProgress.js載入進度外掛程式使用方法
以上是詳細介紹在Bootstrap中為Modal新增拖曳功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用 Bootstrap 獲取搜索欄的值:確定搜索欄的 ID 或名稱。使用 JavaScript 獲取 DOM 元素。獲取元素的值。執行所需的操作。

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

使用 Bootstrap 實現垂直居中:flexbox 法:使用 d-flex、justify-content-center 和 align-items-center 類,將元素置於 flexbox 容器內。 align-items-center 類法:對於不支持 flexbox 的瀏覽器,使用 align-items-center 類,前提是父元素具有已定義的高度。

創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本
