如何利用bootstrap框架做一个拖拽效果,下面web建站小编给大家详细介绍一下具体代码!
找到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"); }); }
在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() }
全球最受欢迎的前端开源工具库——Bootstrap v4中文文档
上面是“bootstrap框架如何实现拖拽效果”的全面内容,想了解更多关于 前端知识 内容,请继续关注web建站教程。
当前网址:https://ipkd.cn/webs_3409.html
workflows工作流
- 一名男子跪在月球岩石表面看见小行星碰撞
- 一个表情深思熟虑的成熟男人
- 一群可爱的小老鼠ComfyUI工作流
- 一个男孩在吃西瓜ComfyUI工作流
- 一座生动的点彩主义灯塔ComfyUI工作流
- 《翅膀之王:鸡的团契》海报ComfyUI工作流
- 一个漂亮的混血女孩ComfyUI工作流
- 一个由红色玻璃制成的女性形状的破碎雕塑
猜你喜欢
声明:本站提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请发送到邮箱:admin@ipkd.cn,我们会在看到邮件的第一时间内为您处理!