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配置与解决方案  米侠浏览器网页图片不显示怎么办 米侠图片加载修复