이 단순화된 버전은 다른 프레임에서 레이어를 팝업할 수 없으므로 cssurl 속성과 대상 속성이 없습니다
코드 복사 코드는 다음과 같습니다.
String.prototype.replaceAll = function(s1,s2){ return this.replace(new RegExp(s1,"gm"),s2); }; (function($){ /* * $-layer 0.1 - New Wave Javascript * * Copyright (c) 2008 King Wong * $Date: 2008-10-09 $ */ var ___id___ = ""; var ___settings___ = {}; var isMouseDown = false; var currentElement = null; var dropCallbacks = {}; var dragCallbacks = {}; var bubblings = {}; var lastMouseX; var lastMouseY; var lastElemTop; var lastElemLeft; var dragStatus = {}; var holdingHandler = false; $.getMousePosition = function(e){ var posx = 0; var posy = 0; if (!e) var e = window.event; if (e.pageX || e.pageY) { posx = e.pageX; posy = e.pageY; } else if (e.clientX || e.clientY) { posx = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft; posy = e.clientY + document.body.scrollTop + document.documentElement.scrollTop; } return { 'x': posx, 'y': posy }; }; $.updatePosition = function(e) { var pos = $.getMousePosition(e); var spanX = (pos.x - lastMouseX); var spanY = (pos.y - lastMouseY); var _top = (lastElemTop + spanY) > 0 ? (lastElemTop + spanY) : 0; var _left = (lastElemLeft + spanX) > 0 ? (lastElemLeft + spanX) : 0; $("#"+___id___).css("top", _top); $("#"+___id___).css("left", _left); }; $.fn.ondrag = function(callback){ return this.each(function(){ dragCallbacks[this.id] = callback; }); }; $.fn.ondrop = function(callback){ return this.each(function(){ dropCallbacks[this.id] = callback; }); }; $.fn.dragOff = function(){ return this.each(function(){ dragStatus[this.id] = 'off'; }); }; $.fn.dragOn = function(){ return this.each(function(){ dragStatus[this.id] = 'on'; }); }; $.extend({ layerSettings:{ id:"layerp", width:220, height:220, templete:'<p style="height:20px; width:@width@px; background-color:#777777;"> <span id="@moveid@" style="position:relative; left:0px; top:0px; height:20px; width:100px;"> <span id="@titleid@">@title@</span></span> <span class="layerclose" style="position:relative; top:0px; float:right; right:20px; color:red;">close</span> </p><p style="border:solid #ff0000 1px; width:@width@px; height:@height@px;"> <p style="width:100%; height:100%; background-color:#ffffff;" id="@contentid@"> </p></p>', content:'', title:'', isbg:true, opacity:0.3 }, layerSetup: function( settings ) { $.extend( $.layerSettings, settings ); ___settings___[settings.id] = settings; ___id___ = settings.id; }, layershow:function(){ var __bw = $("body").width(); var __bh = $("body").height() > $(window).height() ? $("body").height() : $(window).height(); var _width = $.layerSettings.width; var _height = $.layerSettings.height; if(document.getElementById(___id___)) return; var _moveid = ___id___ + "_move"; var _titleid = ___id___ + "_title"; var _contentid = ___id___ + "_content"; var _cssurl = $.layerSettings.cssurl; var opacity = $.layerSettings.opacity; __index = $.layermaxindex(); var __left = (__bw - _width) > 0 ? (__bw - _width)/2 : 0; var __top = 100; var __bgp = '<p id="'+___id___+'_background" style="background:#000000; filter:alpha(opacity='+(opacity*100)+'); opacity: '+opacity+'; width:'+__bw+'px; height:'+__bh+'px; z-index:'+(__index++)+'; position:absolute; left:0px; top:0px;"></p>'; if($.layerSettings.isbg) { $("body").append(__bgp); } $("body").append('<p id="'+___id___+'" style="z-index:'+__index+';position:absolute; left:'+__left+'px; top:'+__top+'px;"></p>'); var _templete = $.layerSettings.templete; var __templete = _templete.replaceAll("@width@",_width).replaceAll("@height@",_height). replaceAll("@titleid@",_titleid).replaceAll("@contentid@",_contentid) .replaceAll("@title@",jQuery.layerSettings.title).replaceAll("@moveid@",_moveid); $("#"+___id___).append(__templete); $("#"+_contentid).append($.layerSettings.content); $("#"+_titleid).append($.layerSettings.title); var idd = ___id___; $(".layerclose").bind("click",function() { $.layerclose(idd); }); $("#"+___id___).bind("click",function() { var id = this.id; $.layerSetup(___settings___[id]); $(this).css("z-index",$.layermaxindex()); }); $(document).bind("click",function(e) { var pos = $.getMousePosition(e); }); $(document).mousemove(function(e){ if(isMouseDown && dragStatus[currentElement.id] != 'false'){ $.updatePosition(e); if(dragCallbacks[currentElement.id] != undefined){ dragCallbacks[currentElement.id](e, currentElement); } return false; } }); $(document).mouseup(function(e){ if(isMouseDown && dragStatus[currentElement.id] != 'false'){ isMouseDown = false; if(dropCallbacks[currentElement.id] != undefined){ dropCallbacks[currentElement.id](e, currentElement); } return false; } }); (function(){ bubblings[___id___] = true; dragStatus[___id___] = "on"; //setHandler bubblings[this.id] = true; dragStatus[_moveid] = "handler"; $("#"+_moveid).css("cursor", "move"); $("#"+_moveid).mousedown(function(e){ var id = this.id.replace("_move",""); ___id___ = id; $("#"+id).css("z-index",$.layermaxindex()); $.layerSetup(___settings___[id]); if((dragStatus[___id___] == "off") || (dragStatus[___id___] == "handler" && !holdingHandler)) return bubblings["#"+___id___]; isMouseDown = true; currentElement = $("#"+___id___); var pos = $.getMousePosition(e); lastMouseX = pos.x; lastMouseY = pos.y; lastElemTop = document.getElementById(___id___).offsetTop; lastElemLeft = document.getElementById(___id___).offsetLeft; $.updatePosition(e); holdingHandler = true; }); $("#"+_moveid).mouseup(function(e){ holdingHandler = false; }); //end setHandler })(); }, layerclose:function(__id) { $("#"+__id+"_background").remove(); $("#"+__id).remove(); }, layermaxindex:function() { var ___index = 0; $.each($("*"),function(i,n){ var __tem = $(n).css("z-index"); if(__tem>0) { if(__tem > ___index) { ___index = __tem + 1; } } }); return ___index; } }); })(jQuery);
사용법:
(1) 표시 레이어:
코드는 다음과 같습니다.
function show() { $.layerSetup({ id:"abc",//弹出层的ID title:"test",//标题 content:'test',//内容 isbg:false,//是否显示背景遮照层 opacity:0.3,//背景遮照层的透明度,值越大透明度越低,0为完全透明,1为不透明 templete:'<p class="showwint_mini_title"><span class="showwint_mini_close_btn"> <a href="javascript:void(null);" class="layerclose"></a></span> <span class="showwint_mini_title_content" id="@moveid@"><span id="@titleid@"></span> </span></p><p class="showwint_mini_content"><p class="showwint_mini_content_content" id="@contentid@"></p> </p>'//模板 }); $.layershow(); }
( 2 ) 레이어 닫기:
코드 복사 코드는 다음과 같습니다.
$.layerclose("弹出层的ID");
참고: 템플릿에 CSS가 있는 경우 파일을 이 페이지로 직접 가져와야 합니다. 이 단순화된 버전은 다른 프레임에 나타날 수 없으므로 cssurl 속성과 대상 속성이 없습니다.
위는 jQuery 팝업 레이어 Plug-in_jquery의 단순화된 버전 코드입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
