jq弹窗拖动改变宽高

预览效果

javascript 复制代码
<div class='tishiMask'>
	<div class="tishiEm">
		<div id="coor"></div>
		<div class="topNew ismove">
			<span class="ismove">提示</span>
			<p onclick="closeTishi()">×</p>
		</div>
		<div class="bottomNew">
			<p>提示文字软件</p>
			<div class="newDesignBtn">
				<input type="button" value="确定" class="btnLeft" onclick="closeTishi()" >
				<input type="button" value="取消" onclick="closeTishi(this)" class="btnRight">
			</div>
		</div>
	</div>
</div>
javascript 复制代码
.tishiMask{
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background-color: rgba(0, 0, 0, .18);
	display: block;
	z-index: 99999;
}
.tishiEm {
	z-index: 99999;
	/* display: none; */
	/* -webkit-transition: -webkit-box-shadow .2s; */
	/* transition: box-shadow .2s; */
	position: fixed;
	height: 220px;
	width: 300px;
	top: 38%;
	/* margin-top: -100px; */
	left: 43%;
	/* margin-left: -150px; */
	background: #fff;
	border-radius: 5px 5px 0px 0px;
	-webkit-box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.4);
	box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.4);
	/* -webkit-transition: -webkit-box-shadow .2s; */
	/* transition: box-shadow .2s; */
	/* transition: all .4s; */
	/* -webkit-transition: all .4s; */
	/* -moz-transition: all .4s; */
}

.tishiEm .topNew {
	overflow: hidden;
	background-image: linear-gradient(183deg, #3d95ea 0%, #70b0e6 100%);
	border-radius: 5px 5px 0px 0px;
}

.tishiEm .topNew span {
	color: #fff;
	font-size: 12px;
	height: 34px;
	line-height: 34px;
	display: block;
	float: left;
	margin-left: 10px;
}

.tishiEm .topNew p {
	float: right;
	color: #fff;
	font-size: 20px;
	height: 34px;
	line-height: 34px;
	display: block;
	margin-right: 10px;
	cursor: pointer;
}

.tishiEm .bottomNew {
	margin: 0px 0px;
}

.tishiEm .bottomNew {
	text-align: center;
}

.tishiEm .bottomNew p {
	font-size: 12px;
	height: 20px;
	line-height: 20px;
}
.tishiEm .bottomNew .newDesignBtn {
	overflow: hidden;
	width: 100%;
	height: auto;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: absolute;
	bottom: 10px;
	left: 0;
}

.tishiEm .bottomNew .newDesignBtn .btnLeft {
	display: block;
	float: left;
	box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.22);
	background: #5da2e5;
	color: #fff;
	font-size: 12px;
	width: auto;
	text-align: center;
	height: 24px;
	line-height: 24px;
	border-radius: 4px;
	border: none;
	cursor: pointer;
	padding: 0px 14px;
	border: 1px solid #5da2e5;
}

.tishiEm .bottomNew .newDesignBtn .btnLeft:hover {
	background: #1a78d9;
	border: 1px solid #0069b8;
	color: #fff;
}

.tishiEm .bottomNew .newDesignBtn .btnRight {
	display: block;
	float: left;
	box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.22);
	background: #dcdcdc;
	color: #383838;
	font-size: 12px;
	width: auto;
	text-align: center;
	height: 24px;
	line-height: 24px;
	border-radius: 4px;
	margin-right: 28px;
	margin-left: 10px;
	border: none;
	cursor: pointer;
	padding: 0px 14px;
	border: 1px solid #dcdcdc;
}

.tishiEm .bottomNew .newDesignBtn .btnRight:hover {
	background: #c4c4c4;
	color: #383838;
	border: 1px solid #aaa;
}
#coor, #coor_set, #coor_syt {
	width: 20px;
	height: 20px;
	overflow: hidden;
	cursor: se-resize;
	position: absolute;
	right: 0;
	bottom: 0;
	/* background-color: #09c; */
	background: url(./../images/scale.png);
	background-size: 100% 100%;
	transform: rotate(270deg);
	z-index: 999;
}

类名tishiEm设置宽高为缩小最小宽高。

注意下方js注释

javascript 复制代码
$(function () {
    $(document).mousemove(function (e) {

        if (!!this.move_gy) {

            var posix_gy = !document.move_target_gy ? { 'x': 0, 'y': 0 } : document.move_target_gy.posix_gy,
                callback_gy = document.call_down_gy || function () {
                    let viewWidth = $(document).width();
                    let maxLeft = viewWidth - $(".tishiEm").width();   // 左侧最大移动量

                    let viewHeight = $(document).height();
                    let maxHeight = viewHeight - $(".tishiEm").height();   // 底部最大移动量

                    let currentTop = e.pageY - posix_gy.y;
                    let currentLeft = e.pageX - posix_gy.x;

                    if (currentTop <= 0 || currentLeft <= 0 || currentLeft >= maxLeft || currentTop >= maxHeight) {
                        return
                    } else {
                        $(this.move_target_gy).offset({
                            'top': currentTop,
                            'left': currentLeft
                        });
                    }
                };

            callback_gy.call(this, e, posix_gy);
        }


    }).mouseup(function (e) {
        if (!!this.move_gy) {
            var callback_gy = document.call_up_gy || function () {
            };
            callback_gy.call(this, e);
            $.extend(this, {
                'move_gy': false,
                'move_target_gy': null,
                'call_down_gy': false,
                'call_up_gy': false
            });
        }
    });
    var $box = $('.tishiEm').mousedown(function (e) {
        let offset = $(this).offset();


        this.posix_gy = { 'x': e.pageX - offset.left, 'y': e.pageY - offset.top };
        if (!$(e.target).hasClass('ismove')) {      // 只允许蓝色区域可拖动
            return;
        } else {
            $.extend(document, { 'move_gy': true, 'move_target_gy': this });
        }


    }).on('mousedown', '#coor', function (e) {
        var posix_gy = {
            'w': $box.width(),
            'h': $box.height(),
            'x': e.pageX,
            'y': e.pageY
        };

        $.extend(document, {
            'move_gy': true, 'call_down_gy': function (e) {
            	//下方为最小宽高  同步上方css
                $box.css({
                    'width': Math.max(300, e.pageX - posix_gy.x + posix_gy.w),
                    'height': Math.max(220, e.pageY - posix_gy.y + posix_gy.h)
                });
            }
        });
        return false;
    });
});
相关推荐
掘金一周1 分钟前
金石焕新程 >> 瓜分万元现金大奖征文活动即将回归 | 掘金一周 4.3
前端·人工智能·后端
三翼鸟数字化技术团队19 分钟前
Vue自定义指令最佳实践教程
前端·vue.js
Enti7c23 分钟前
HTML5和CSS3的一些特性
开发语言·css3
Jasmin Tin Wei1 小时前
蓝桥杯 web 学海无涯(axios、ecahrts)版本二
前端·蓝桥杯
圈圈编码1 小时前
Spring Task 定时任务
java·前端·spring
转转技术团队1 小时前
代码变更暗藏危机?代码影响范围分析为你保驾护航
前端·javascript·node.js
Mintopia1 小时前
Node.js高级实战:自定义流与Pipeline的高效数据处理 ——从字母生成器到文件管道的深度解析
前端·javascript·node.js
Mintopia1 小时前
Three.js深度解析:InstancedBufferGeometry实现动态星空特效 ——高效渲染十万粒子的底层奥秘
前端·javascript·three.js
北凉温华1 小时前
强大的 Vue 标签输入组件:基于 Element Plus 的 ElTagInput 详解
前端
随笔记1 小时前
Flex布局下,label标签设置宽度依旧对不齐,完美解决(flex-shrink属性)
javascript·css·vue.js