angularjs modal模态框----创建可拖动的指令集

//最近项目中需要将angular-ui-bootstrap中用到的弹出框,使之可拖动,由于源文件中没有实现,需要自己实现指令,以下即为该指令,亲测可以实现。
.directive('draggable', ['$document', function($document) { return function(scope, element, attr) { var startX = 0, startY = 0, x = 0, y = 0; element= angular.element(document.getElementsByClassName("modal-dialog")); element.css({ position: 'relative', cursor: 'move' }); element.on('mousedown', function(event) { // Prevent default dragging of selected content event.preventDefault(); startX = event.pageX - x; startY = event.pageY - y; $document.on('mousemove', mousemove); $document.on('mouseup', mouseup); }); function mousemove(event) { y = event.pageY - startY; x = event.pageX - startX; element.css({ top: y 'px', left: x 'px' }); } function mouseup() { $document.off('mousemove', mousemove); $document.off('mouseup', mouseup); } }; }]);

 如图:已不在屏幕中央,为拖动后的效果


更多专业前端知识,请上 【猿2048】www.mk2048.com
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现多个弹出框,可以通过动创建多个框的方式来实现。以下是一种实现方法: 1. 在 HTML 中添加一个按钮,用于触发弹出框: ```html <button id="btnOpenModal" class="btn btn-primary">打开框</button> ``` 2. 在 JavaScript 中编写代码,用于动创建框: ```javascript // 框计数器,用于生成唯一的 ID var modalCount = 0; // 创建框函数 function createModal() { // 创建框 HTML var modalHTML = '<div id="modal' + modalCount + '" class="modal fade" tabindex="-1" role="dialog">'; modalHTML += '<div class="modal-dialog" role="document">'; modalHTML += '<div class="modal-content">'; modalHTML += '<div class="modal-header">'; modalHTML += '<h5 class="modal-title">框标题</h5>'; modalHTML += '<button type="button" class="close" data-dismiss="modal" aria-label="Close">'; modalHTML += '<span aria-hidden="true">×</span>'; modalHTML += '</button>'; modalHTML += '</div>'; modalHTML += '<div class="modal-body">'; modalHTML += '<p>框内容</p>'; modalHTML += '</div>'; modalHTML += '<div class="modal-footer">'; modalHTML += '<button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>'; modalHTML += '<button type="button" class="btn btn-primary">保存</button>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; // 将框 HTML 添加到页面中 $('body').append(modalHTML); // 增加计数器,确保每个框具有唯一的 ID modalCount++; // 返回最新创建框的 ID return 'modal' + (modalCount - 1); } ``` 3. 在 JavaScript 中编写代码,用于打开框: ```javascript // 点击按钮时打开框 $('#btnOpenModal').click(function () { // 创建一个新的框 var modalId = createModal(); // 打开新的框 $('#' + modalId).modal('show'); }); ``` 这样就可以通过点击按钮来打开多个框了。每次点击按钮时,都会动创建一个新的框,并打开它。注意,这里使用了 jQuery 和 Bootstrap 的 JavaScript 插件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值