찾다
웹 프론트엔드JS 튜토리얼jQuery 타이머 간단한 애플리케이션 지침_jquery

편의상 Jquery는 JS의 setTimeout 및 setInterval 메서드를 캡슐화했습니다. 적용 예를 살펴보겠습니다.

코드 복사 코드는 다음과 같습니다.

/**
* jQuery.timers - jQuery용 타이머 추상화
* 작성자: Blair Mitchelmore(blair DOT mitchelmore AT gmail DOT com)
* WTFPL(http://sam.zoy.org/wtfpl/)에 따라 라이센스가 부여됨 ).
* 날짜: 2009/10/16
*
* @author Blair Mitchelmore
* @version 1.2
*
**/

jQuery.fn.extend({
everyTime: function(interval, label, fn, times) {
return this .each(function() {
jQuery.timer.add(this, Interval, label, fn, times);
});
},
oneTime : function(interval, label, fn ) {
return this.each(function() {
jQuery.timer.add(this, 간격, label, fn, 1);
}); >},
stopTime: function(label, fn) {
return this.each(function() {
jQuery.timer.remove(this, label, fn);
}); 🎜>}
}) ;

jQuery.extend({
timer: {
global: [],
guid: 1,
dataKey: "jQuery.timer ",
정규식: / ^([0-9] (?:.[0-9]*)?)s*(.*s)?$/,
힘: {
// 그래 이건 너무 과한 짓이야...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das' : 10000,
'hs': 100000,
'ks': 1000000
},
timeParse: function(value) {
if (값 == 정의되지 않음 || 값 == null )
return null;
var result = this.regex.exec(jQuery.trim(value.toString()))
if (result[2]) {
var num = parseFloat( result[1]);
var mult = this.powers[result[2]] || 1;
return num * mult
} else {
반환 값; 🎜>},
add : 함수(요소, 간격, 레이블, fn, 시간) {
var counter = 0

if (jQuery.isFunction(label)) {
if (!times)
times = fn;
fn = label;
label = 간격;

interval = jQuery.timer.timeParse(간격); 🎜>if (typeof 간격 != '숫자' || isNaN(간격) || 간격 return

if (typeof times != '숫자' || isNaN(times) || 회 회 = 0;

var 타이머 = jQuery.data(element, this.dataKey) || data(element, this.dataKey, {});

if (!timers[label])
timers[label] = {}

fn.timerID = fn.timerID || this.guid ;

var handler = function() {
if (( counter > times && times !== 0) || fn.call(element, counter) === false )
jQuery.timer.remove(element, label, fn)

handler.timerID = fn.timerID; fn.timerID])
타이머[label][fn.timerID] = window.setInterval(handler,interval);

this.global.push( 요소 )

};
remove: function(element , label, fn) {
var 타이머 = jQuery.data(element, this.dataKey), ret

if ( 타이머 ) {

if (!label) {
for ( 타이머의 라벨 )
this.remove(element, label, fn)
} else if ( 타이머[label] ) {
if ( fn ) {
if ( fn.timerID ) {
window.clearInterval(timers[label][fn.timerID])
delete 타이머[label][fn.timerID]
}
} else {
for ( var fn in 타이머[label] ) {
window.clearInterval(timers[label][fn])
delete 타이머[label][fn]}
> >}

for ( ret in 타이머 ) break;
if ( !ret )
jQuery.removeData(element, this.dataKey)
}
}
}
})

jQuery(window).bind("unload", function() {
jQuery.each(jQuery.timer.global, function(index, item) {
jQuery.timer.remove(item) ;
});
});


JS 코드




🎜>

코드는 다음과 같습니다:


$("#close-button").click(function() {
$(this).oneTime(1000 , function() {
$(this ).parent(".main-window").hide();
})
$("#cancel-button" ).click(function() {
$("#close-button").stopTime();
})

jQuery 타이머 플러그인 주소:

http://plugins.jquery.com/ project/timers
JavaEye 포럼의 다음 JQuery Timers 애플리케이션 지식은 세 가지 기능을 제공합니다1. 간격, [타이머 이름], 함수 수식 이름, [횟수 제한], [함수 프로그램 완료 대기]) 2. oneTime(시간 간격, [타이머 이름], 호출되는 함수)
3. [타이머 이름], [기능 이름])




코드 복사


코드는 다음과 같습니다.

/**************************************************** * *********
* EveryTime(시간 간격, [타이머 이름], 함수 이름, [횟수 제한], [함수 프로그램 완료 대기])
******** ************************************************** * *****/

//1초마다 function test() 실행
function test(){
//뭔가를 하세요...
}
$('body').everyTime('1s',test);

//1초마다 실행
$('body').everyTime('1s', function (){
//뭔가를 하세요...
})

//1초마다 실행하고 타이머 이름을 A
$('body')로 지정합니다. '1s','A',function(){
//뭔가를 하세요...
})

//20초마다 최대 5번 실행하고 타이머 이름을 지정합니다. 장치 이름은 B
$('body').everyTime('2das','B',function(){
//뭔가를 하세요...
},5);
//20초마다 무제한으로 실행하고 타이머 이름을 C로 지정합니다.
//시간 간격에 도달했지만 함수 프로그램이 완료되지 않은 경우 실행 함수가 완료될 때까지 기다려야 합니다. 시간을 계속하기 전에
$('body').everyTime('2das','C',function(){
//20초 이상 걸리는 프로그램 실행
},0, true);

/**************************************************** * *******
* oneTime(시간 간격, [타이머 이름], 호출되는 함수)
******************** ** **************************************/
//10초 카운트다운 후 실행
$('body').oneTime('1das',function(){
//뭔가를 하세요...
})

//카운트다운 100초 후에 실행하고 타이머 이름을 D
$('body').oneTime('1hs', 'D',function() {
//뭔가를 하세요...
})

/**************************************************** * ********
* stopTime ([타이머 이름], [함수 이름])
************************ ** ****************************************/
//$('에서 모든 타이머를 중지합니다. body')
$('body').stopTime ()

//$('body')
$('body').stopTime ('에서 A라는 타이머를 중지합니다. A' );

//$('body')
$('body').stopTime (test)

에서 test()를 호출하는 모든 타이머를 중지합니다. 사용자 정의 시간 단위
소스 코드 열기
찾기

코드 복사 코드는 다음과 같습니다.
powers: {
// 예, 이건 엄청난 과잉입니다...
'ms': 1,
'cs': 10,
'ds': 100,
': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
}

사용자 정의할 수 있습니다. 당신이 원하는 것!
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
jquery实现多少秒后隐藏图片jquery实现多少秒后隐藏图片Apr 20, 2022 pm 05:33 PM

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

jquery怎么修改min-height样式jquery怎么修改min-height样式Apr 20, 2022 pm 12:19 PM

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

axios与jquery的区别是什么axios与jquery的区别是什么Apr 20, 2022 pm 06:18 PM

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

jquery怎么在body中增加元素jquery怎么在body中增加元素Apr 22, 2022 am 11:13 AM

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

jquery中apply()方法怎么用jquery中apply()方法怎么用Apr 24, 2022 pm 05:35 PM

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

jquery怎么删除div内所有子元素jquery怎么删除div内所有子元素Apr 21, 2022 pm 07:08 PM

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

jquery on()有几个参数jquery on()有几个参数Apr 21, 2022 am 11:29 AM

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

jquery怎么去掉只读属性jquery怎么去掉只读属性Apr 20, 2022 pm 07:55 PM

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

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는