亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

詳解為Bootstrap Modal添加拖拽的方法

2024-05-06 16:41:48
字體:
來源:轉載
供稿:網友

網上有許多給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居中也可修改源代碼來完成。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合久久精品亚洲国产| 国精产品一区一区三区有限在线| 日韩综合中文字幕| 日韩最新免费不卡| 热久久免费视频精品| 萌白酱国产一区二区| 欧美激情区在线播放| 在线国产精品视频| 日韩精品中文字幕在线观看| 亚洲黄色成人网| 日韩免费高清在线观看| 精品久久久久久久久国产字幕| 亚洲伊人第一页| 欧美性生交xxxxx久久久| 亚洲精品电影网| 色婷婷综合成人| 亚洲第一区中文99精品| 亚洲免费中文字幕| 97视频国产在线| 亚洲成色777777在线观看影院| 91国产精品视频在线| 欧美日韩国产专区| 黑人巨大精品欧美一区二区免费| 欧美最猛黑人xxxx黑人猛叫黄| 国产成人一区二区三区| 国产精品白丝av嫩草影院| 91国语精品自产拍在线观看性色| 亚洲人成欧美中文字幕| 亚洲精品永久免费精品| 国产精品一区二区久久精品| 91久久在线视频| 日韩av毛片网| 亚洲黄色www| 日韩中文在线中文网三级| 亚洲a级在线播放观看| 日韩av在线免费| 国产精品青草久久久久福利99| 影音先锋欧美在线资源| 九色精品美女在线| 亚洲精品成人免费| 日韩精品极品毛片系列视频| 精品日本美女福利在线观看| 欧美日本精品在线| 色综合影院在线| 亚洲天堂日韩电影| 欧美电影在线观看网站| 亚洲欧美日韩一区二区三区在线| 日韩在线观看免费高清| 欧美日韩裸体免费视频| 亚洲韩国日本中文字幕| 7777kkkk成人观看| 国产精品美乳在线观看| 最新亚洲国产精品| 久久精品2019中文字幕| 欧美成人性色生活仑片| 成人欧美一区二区三区黑人| 欧美在线视频一区| 久久成人国产精品| 亚洲精品之草原avav久久| 久久精品国产成人精品| 成人黄色片网站| 亚洲国产精品久久久久秋霞蜜臀| 欧美在线视频在线播放完整版免费观看| 黑人极品videos精品欧美裸| 操日韩av在线电影| 色婷婷**av毛片一区| 91香蕉电影院| 成人中文字幕+乱码+中文字幕| 日韩av在线精品| 欧美亚洲午夜视频在线观看| 中文字幕成人在线| 国产精品爽爽爽| 久久精品中文字幕电影| 在线播放国产一区中文字幕剧情欧美| 亚洲性视频网站| 黑人巨大精品欧美一区二区一视频| 国产亚洲精品久久久久动| 国产成人a亚洲精品| 国产精品国产福利国产秒拍| 成人中文字幕在线观看| 久久精品夜夜夜夜夜久久| 日韩亚洲成人av在线| 91高清视频在线免费观看| 91精品国产免费久久久久久| 狠狠色香婷婷久久亚洲精品| 国产裸体写真av一区二区| 欧美一级片久久久久久久| 成人网页在线免费观看| 日韩美女视频中文字幕| 精品国产一区二区三区久久久| 亚洲精品自拍偷拍| 欧美视频一区二区三区…| 亚洲视频在线免费看| 国产精品国产福利国产秒拍| 国产精品女视频| 色噜噜狠狠狠综合曰曰曰| 狠狠躁18三区二区一区| 国产一区二区三区在线免费观看| 国产成人激情小视频| 精品无码久久久久久国产| 日韩成人久久久| 精品电影在线观看| 夜夜狂射影院欧美极品| 国产精品久久久久久久久久东京| 国产精品视频男人的天堂| 国产精品麻豆va在线播放| 亚洲第一福利在线观看| 国产欧美日韩视频| 久久99精品久久久久久青青91| 精品调教chinesegay| 综合136福利视频在线| 色噜噜国产精品视频一区二区| 欧美性开放视频| 久久免费在线观看| 欧美极品少妇与黑人| 日韩精品极品毛片系列视频| 国内精品久久久久影院 日本资源| 日韩av在线看| 亚洲国产精品成人一区二区| 久久影院资源站| 国产精品扒开腿做爽爽爽视频| 久久久久亚洲精品国产| 国产精品视频久久久久| 中文字幕亚洲色图| 91a在线视频| 欧美亚州一区二区三区| 亚洲电影天堂av| 成人午夜在线视频一区| 欧美国产极速在线| 久久久国产一区| 国产91精品青草社区| 日本不卡视频在线播放| 狠狠色狠狠色综合日日五| 午夜精品一区二区三区视频免费看| 国产999在线观看| 日韩高清中文字幕| 岛国av在线不卡| 国产91九色视频| 亚洲国产成人在线视频| 欧美午夜精品在线| 精品色蜜蜜精品视频在线观看| 欧美亚洲激情视频| 国产精品视频内| 夜夜嗨av一区二区三区四区| 精品久久久久久亚洲国产300| 成人av在线天堂| 欧美大片免费观看在线观看网站推荐| 中文字幕欧美日韩va免费视频| 欧美电影免费观看电视剧大全| 日韩av有码在线| 亚洲嫩模很污视频| 亚洲美女在线观看| 日韩在线观看精品| 成人欧美一区二区三区黑人孕妇| 日韩经典第一页| 国产成人欧美在线观看| 91禁外国网站| 国产综合香蕉五月婷在线| 九九九热精品免费视频观看网站| 国产一区二区三区在线播放免费观看| 欧美激情欧美激情| 91久久国产综合久久91精品网站| 久久人人爽亚洲精品天堂| 日本久久91av|