美文网首页
2019-02-23_js_07定时器、函数

2019-02-23_js_07定时器、函数

作者: 陳先生_2211 | 来源:发表于2019-04-11 19:43 被阅读0次

定时器、函数

一、定时器

1.)setTimeout(function(){},time) 单次执行
    表示在time毫秒后执行function
2.)clearTimeout(timer):清除计时器
    timer:表示定义的计时器
3.)setInterval(function(){},time):可循环执行function
      表示每隔time毫秒后执行的函数
4.)clearInterval(timer)
    timer:表示定义的计时器
//鼠标按下时间
var div = document.querySelector(".test");
//封装长按功能函数
function longpress(el,callback){//el:传入元素、callback:传入一个函数
    var timer;
    el.addEventListener("mousedown",function(){
        timer = setTimeout(function(){//长按
                callback();
            },1000)
        })
    //鼠标抬起
    document.addEventListener("mouseup",function(){
        //console.log("鼠标被抬起了");
        clearTimeout(timer);//清除计时器
    })
        
    }
longpress(div,function(){
    alert("哈哈哈哈");
});
//模拟一个双击事件(提示,用定时器实现)
function twoClick(el,callback){
    var isClick = false;
    el.addEventListener("click",function(){
        if(isClick==true){
            callback();
            isClick = false;
            clearTimeout(t);
        }else{
            isClick = true;
            var t = setTimeout(function(){
                isClick = false;
            },300)
        }
    })
}

二、函数

函数无论在声明的前面或者是声明的后面都可以调用
argument:数组的形式接收函数的参数
length:获取到函数的形参个数

function calc(){
    if(arguments.length==1){
        alert("你的名字:"+arguments[0]+"\n 经过我的神机妙算,你的未来无可限量");
    }else{
        alert("请输入你的名字");
    }
}
calc("啥啥啥");//函数提前,无论在声明的后面还是前面,都可以调用
console.log(calc.length);

闭包(函数体内嵌套函数):使得函数可以调用其他函数体内变量

//valueOf
function fun(){
    var x = 1;
    // 闭包(函数体内嵌套函数)
    function func(){
        console.log("我是func函数里面的函数",x);
    }
    func();
    return x;
}
fun();
console.log(fun.valueOf());//获取函数体
console.log(typeof fun.toString());//输出函数 类型是字符串

1.函数声明的方式:

      1)函数声明:function name(){}
      2)函数表达式:var fun = function(){}
         调用方法:变量名+小括号
      3)箭头函数(es6语法):
          第一种形式:()=>{};
          第二种形式:(name=>{})();
          第三种形式:(name=>())();
  注意:
      当我们使用函数表达式的方式来声明函数的时候,也给了函数名,
      这个函数名是不能够在函数体外进行调用,只能够在函数体内调用
//当我们使用函数表达式的方式来声明函数的时候,也给了函数名,
//这个函数名是不能够在函数体外进行调用,只能够在函数体内调用
var test = function func1(){
    console.log(func1);
    console.log("哈哈哈");
}
console.log(test.name);//func1
//          func1();//直接报错  func1 is not defined 一整个是一个值
test();//哈哈哈
go1();//函数声明,调用第二个函数 因为全局任意地方都可以调用
var go1 = function(){
    console.log("函数表达式")
}
go1();//函数表达式
function go1(){
    console.log("函数声明");
}//会提前,被覆盖掉
go1();//函数表达式

2.函数this的指向(箭头函数除外):

谁调用函数,这个this就指向谁
this的指向一般有3种情况:
        1.全局作用域内调用函数,this指向window
        2.通过事件来调用函数,this指向这个事件的调用者
        3.对象调用其方法,this指向这个对象
setTimeout(function(){
    console.log(this);//window
},1000)
window.setTimeout(function(){
    console.log("通过window来调用定时器",this);
},1000)//setTimeout是window的方法


function foo(){
    console.log(this);//window
}
foo();//最大的对象是window
var div = document.querySelector(".test");
div.addEventListener("click",function(){
    console.log(this);//div
});

//对象的方法调用
var obj ={
    name:"bgg神教,一统江湖",
    skill:function(){
        console.log(this);
    }
}
//obj.skill();//obj
var skr = obj.skill;
skr();//window

div.addEventListener("click",()=>{
    console.log(this);
});//window //箭头函数指向window

3.箭头函数案例

//箭头函数()=>{}
//第一种
((age)=>{
    console.log(age);
    console.log(window);
})(20);

//箭头函数()=>{}
//第二种
(age =>{
    console.log(age);
})(222);
setTimeout(age =>{
    console.log("sss")
},1000);

//箭头函数()=>{}
//第三种 只能写一个语句(语句后不能有分号;)
(age=>console.log(age))(888);
//(age=>console.log(age);console.log("aaaaa");)(888);//报错

相关文章

  • 2019-02-23_js_07定时器、函数

    定时器、函数 一、定时器 二、函数 函数无论在声明的前面或者是声明的后面都可以调用argument:数组的形式接收...

  • 运动控制器19:步进控制文件的初始化(选用定时器2)

    控制步进输出的定时器TIM2初始化函数 我们再设置一个开启定时器和关闭定时器的函数:开启定时器的函数名称:st_w...

  • python 线程定时器

    基本思想是:函数中使用线程定时器函数调用自己。当然,用户自己在函数外使用线程定时器函数起个头。 自己起个头:

  • 19 - Toggling the Spawn Volumes

    给SpawnVolume添加 生成电池控制函数 通过该函数 添加 删除电池生成定时器定时器 最终SpawnVolu...

  • 定时器

    定时器 setInterval(函数,毫秒); 重复执行 clearIntrval(setInterval(函数...

  • DSP_代码笔记(基于TMS320X281x)| CPU定时器0

    CPU定时器0模块初始化: 主函数模块: CPU定时器0周期中断函数:

  • 10.12

    通用定时器,时基初始化配置: 计数模式,分频值,重载值,采样时钟。用到了定时器使能函数,定时器中断使能函数,状态标...

  • 定时器,Math方法

    1.定时器:setTimeout 只执行一次setInterval 循环定时器 2.回调函数:用来接收函数...

  • This的指向总结

    1、//定时器中this的指向 结论:如果由定时器调用执行了某个函数,函数中有this,则这个this指向wind...

  • 定时器 类型转换 封闭函数

    定时器定时器在javascript中的作用1、制作动画2、异步操作3、函数缓冲与节流 定时器类型及语法 /*定时器...

网友评论

      本文标题:2019-02-23_js_07定时器、函数

      本文链接:https://www.haomeiwen.com/subject/xifnyqtx.html