JavaScript实现弹窗效果代码分析
发布时间 - 2026-01-11 00:05:47 点击率:次效果图:
话不多说,请看代码:
每个弹窗的标识
var x =0;
var idzt = new Array();
var Window = function(config){
ID不重复
idzt[x] = "zhuti"+x; 弹窗ID
初始化,接收参数
this.config = {
width : config.width || 300, 宽度
height : config.height || 200, 高度
buttons : config.buttons || '', 默认无按钮
title : config.title || '标题', 标题
content : config.content || '内容', 内容
isMask : config.isMask == false?false:config.isMask || true, 是否遮罩
isDrag : config.isDrag == false?false:config.isDrag || true, 是否移动
};
加载弹出窗口
var w = ($(window).width()-this.config.width)/2;
var h = ($(window).height()-this.config.height)/2;
var nr = "<div class='zhuti' id='"+idzt[x]+"' bs='"+x+"' style='width:"+this.config.width+"px; height:"+this.config.height+"px; left:"+w+"px; top:"+h+"px;'></div>";
$("body").append(nr);
加载弹窗标题
var content ="<div id='title"+x+"' class='title' bs='"+x+"'>"+this.config.title+"<div id='close"+x+"' class='close' bs='"+x+"'>×</div></div>";
加载弹窗内容
var nrh = this.config.height - 75;
content = content+"<div id='content"+x+"' bs='"+x+"' class='content' style='width:100%; height:"+nrh+"px;'>"+this.config.content+"</div>";
加载按钮
content = content+"<div id='btnx"+x+"' bs='"+x+"' class='btnx'>"+this.config.buttons+"</div>";
将标题、内容及按钮添加进窗口
$('#'+idzt[x]).html(content);
创建遮罩层
if(this.config.isMask)
{
var zz = "<div id='zz'></div>";
$("body").append(zz);
$("#zz").css('display','block');
}
最大最小限制,以免移动到页面外
var maxX = $(window).width()-this.config.width;
var maxY = $(window).height()-this.config.height;
var minX = 0,
minY = 0;
窗口移动
if(this.config.isDrag)
{
鼠标移动弹出窗
$(".title").bind("mousedown",function(e){
var n = $(this).attr("bs"); 取标识
使选中的到最上层
$(".zhuti").css("z-index",3);
$('#'+idzt[n]).css("z-index",4);
取初始坐标
var endX = 0, 移动后X坐标
endY = 0, 移动后Y坐标
startX = parseInt($('#'+idzt[n]).css("left")), 弹出层的初始X坐标
startY = parseInt($('#'+idzt[n]).css("top")), 弹出层的初始Y坐标
downX = e.clientX, 鼠标按下时,鼠标的X坐标
downY = e.clientY; 鼠标按下时,鼠标的Y坐标
绑定鼠标移动事件
$("body").bind("mousemove",function(es){
endX = es.clientX - downX + startX; X坐标移动
endY = es.clientY - downY + startY; Y坐标移动
最大最小限制
if(endX > maxX)
{
endX = maxX;
} else if(endX < 0)
{
endX = 0;
}
if(endY > maxY)
{
endY = maxY;
} else if(endY < 0)
{
endY = 0;
}
$('#'+idzt[n]).css("top",endY+"px");
$('#'+idzt[n]).css("left",endX+"px");
window.getSelection ? window.getSelection().removeAllRanges():document.selection.empty(); //取消选中文本
});
});
鼠标按键抬起,释放移动事件
$("body").bind("mouseup",function(){
$("body").unbind("mousemove");
});
}
关闭窗口
$(".close").click(function(){
var m = this.getAttribute("bs"); 找标识
$('#'+idzt[m]).remove(); 移除弹窗
$('#zz').remove(); 移除遮罩
})
x++; 标识增加
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js
# 弹窗
# JavaScript定时器制作弹窗小广告
# js实现弹窗暗层效果
# 关于vue.js弹窗组件的知识点总结
# js弹出框、对话框、提示框、弹窗实现方法总结(推荐)
# JS实现可拖曳、可关闭的弹窗效果
# js实现仿MSN带关闭功能的右下角弹窗代码
# js弹窗返回值详解(window.open方式)
# js弹窗代码 可以指定弹出间隔
# js退出弹窗代码集合
# js点击弹出div层实现可拖曳的弹窗效果
# 鼠标
# 弹出
# 加载
# 按下
# 移除
# 多说
# 关闭窗口
# 绑定
# 弹出窗口
# 最上层
# 窗内
# content
# false
# isMask
# top
# title
# buttons
# left
# lt
# nr
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何自定义建站之星网站的导航菜单样式?
昵图网官网入口 昵图网素材平台官方入口
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
Laravel如何实现文件上传和存储?(本地与S3配置)
如何自定义建站之星模板颜色并下载新样式?
如何在香港服务器上快速搭建免备案网站?
Laravel如何配置Horizon来管理队列?(安装和使用)
微信小程序 配置文件详细介绍
Laravel storage目录权限问题_Laravel文件写入权限设置
JS碰撞运动实现方法详解
实现点击下箭头变上箭头来回切换的两种方法【推荐】
北京的网站制作公司有哪些,哪个视频网站最好?
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
Swift中switch语句区间和元组模式匹配
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
如何在阿里云域名上完成建站全流程?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
中山网站推广排名,中山信息港登录入口?
如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何在万网ECS上快速搭建专属网站?
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
音响网站制作视频教程,隆霸音响官方网站?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
微信小程序 input输入框控件详解及实例(多种示例)
详解jQuery中基本的动画方法
Laravel如何使用Livewire构建动态组件?(入门代码)
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
javascript中对象的定义、使用以及对象和原型链操作小结
Laravel如何使用Vite进行前端资源打包?(配置示例)
Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)
如何用景安虚拟主机手机版绑定域名建站?
Laravel如何保护应用免受CSRF攻击?(原理和示例)
如何在云主机快速搭建网站站点?
Laravel如何自定义分页视图?(Pagination示例)
利用JavaScript实现拖拽改变元素大小
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析
Laravel如何处理CORS跨域请求?(配置示例)
Laravel如何实现用户注册和登录?(Auth脚手架指南)
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
米侠浏览器网页图片不显示怎么办 米侠图片加载修复

