如何利用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,我们会在看到邮件的第一时间内为您处理!