`
yumo12
  • 浏览: 18627 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

JS一起学04:函数返回值、定时器、随机数、自动播放的幻灯片

    博客分类:
  • js
阅读更多
一、函数返回值----将相应的值返回到函数调用的地方
1. 可以不写返回值
2. 可以没有return,如果不返回,默认返回undefined
3. 本函数内,renturn之后的JS语句不再执行,跳出
4. 可以返回任意类型
例一
window.onload=function() { 
 function fn() { 
      var a=4;
      alert(123);
      return a+1;
      alert(456);
 };
 //默认返回undefined
 alert( fn() );
};
例二:
function fn(){ 
    var a=4; 
    return [a];
}
var n=fn();
alert()n[0];
 function fn(){
      var a=4;
      return function(){
           alert(a);
      };
 };
 //默认返回undefined
 //var n=fn(); //闭包
 fn()();
5. 函数预解析,函数可以先用后定义---->同一个作用域下
var oBtn=document.getElementById('btn');
oBtn.onclick=function(){
    fn(3);
}
function fn(a){     //预解析
    alert(a);
}
6. 局部函数也会预解析:当JS执行到这个函数的时候才会预解析。
fn();
function fn(){
    fn2();
    function fn2(){
        alert(444);
    }
}    
7. 变量也会预解析,可以理解为提前设定 var a; 只有var,才会预解析
8. return时函数就结束了,return 后面的代码不会执行。没有return 时,返回undefined
例一:
var a=5;
function fn(){
    alert(a);
    var a=4;
    alert(a);
}
fn(a);
alert(a);   //全局变量不受局部影响
例二:
var a=5;
function fn(){
    alert(a);   //5
    a=4;
    alert(a);  //4
}
fn();
alert(a);   //4
9. 一个函数应该只返回一种类型的值
        function show(a,b){
            return a+b;
        }
        alert(show(11,12));
变量、参数、返回值——可以装任何东西(数字、字符串、元素、数组、函数)
二、定时器
定时器---同一个对象 : 每次用之前先清掉上一次
定时器中不能用this
1. 开启定时器
  (1) setInterval  间隔型
  (2) setTimeout 延时型
            可以在函数内部调用函数自己
                function f(){
                    alert(123)
                    setTimeout(f,1000);
                }
                setTimeout(f,1000);
2. 停止定时器
clearInterval / clearTimeout
    var oBtn1=document.getElementById('btn1');
    var oBtn2=document.getElementById('btn2');
    oBtn1.onclick=function(){
        timer=setInterval(function(){
            alert('a')
        },3000);
    }
     oBtn2.onclick=function(){
        clearInterval(timer);
    }
3. var oBox=document.getElementById('box');
    function f(){
        alert(123);
    }
    // setInterval('alert(11)',500);   //第一个参数也可以放字符串,相当于eval
    setInterval(f,500);
4.闪烁提醒
    var timer; 
    oBtn.onclick=function(){
        oDiv1.style.display=oShadow.style.display='block';
    }
    oShadow.onclick=function(){
        clearInterval(timer);
        timer=setInterval(function(){
            var n=0;
            n++;
            n%2==0?oH1.style.background='#ccc':oH1.style.background='#f00';
            n=20&&clearInterval(timer);
        },50);
    }
5. 双色球
function findSame(arr,n){
     for(var i=0;i<arr.length;i++){
          if(arr[i]==n){
               return false;
          }
          return true;
     }
}
function rnd(n,m){
     return parseInt(Math.random()*(m-n+1)+n);
}
function toDou(n){
     if(n<10){
          return '0'+n;
     }
     return ''+n;
}
window.onload=function(){
     var oBtn=document.getElementById('btn');
     var oBox=document.getElementById('box');
     var arr=[];
     oBox.innerHTML='';
     oBtn.onclick=function(){
          while(arr.length<6){
               var number=rnd(1,33);
               if(findSame(arr,number)){
                    arr[arr.length]=toDou(number);
               }
           }
            arr[arr.length]=toDou(rnd(1,16));
            for(var i=0;i<arr.length;i++){
                var Class=i==arr.length-1?'blue':'';
                oBox.innerHTML+='<span class="'+Class+'">'+arr[i]+'</span>';
           };
      }
}
6. 延时提示框
    (1) 移除延时隐藏----移入下面的div后,还是隐藏了
    (2) 简化代码----把长得像的变成长得一样的。合并两个相同的mouseover和mouseout。连等。
三、随机数
1. Math:处理数学任务
 0    <=   Math.random()   <1
0     <=   Math.random()*100  <100
2. 公式:求n-m(不会出现m)        Math.random()*(m-n)+n
              求n-m(出现m)               Math.random()*(m-n+1)+n
              Math.random()*(大-小)+小
例一:随机数
window.onload=function(){
    for(var i=0;i<100;i++){
       //0-1      document.write(Math.random()+'<br />');
      //0-100   document.write(Math.random()*100+'<br />');
     //10-30   document.write(Math.random()*20+10+'<br />');
     //5-20包括20  document.write(Math.random()*(20-5+1)+5+'<br />');
    }
}
例二:随机颜色
window.onload=function(){
    var oBox=document.getElementById('box');
    oBox.onclick=function(){
        var r=rnd(0,255); 
        var g=rnd(0,255); 
        var b=rnd(0,255); 
        this.style.background='rgb('+r+','+g+','+b+')';
    }
function rnd(n,m){
    return parseInt(Math.random()*(m-n)+n);
}
例三:彩票
function rnd(n,m){
    return parseInt(n+Math.random()*(m-n));
}
var arr=[];
var num;
while(arr.length<6){
    num=rnd(1,33);
    if(findInArr(n,m){
        arr.push(num);
    }
}
alert(arr);
function findInArr(arr,n){
    for(var i=0;i<arr.length;i++){
        if(arr[i]==n){
            return false;
        }
    }
    return true;
}
四、自动播放的幻灯片
var oBox=document.getElementById('box');
var aBtn=oBox.getElementsByTagName('input');
var aDiv=oBox.getElementsByTagName('div');
for(var i=0;i<aBtn.length;i++){
     aBtn[i].index=i;
     aBtn[i].onclick=function(){
          for(var i=0;i<aBtn.length;i++){
               aBtn[i].className='';
               aDiv[i].className='';
          }
          this.className='active';
          aDiv[this.index].className='show';
     }
     if(aBtn[i].className=='active') iNow=i; 
}
function f(){
    iNow++;
    if(iNow==aBtn.length)iNow=0;
    for(var i=0;i<aBtn.length;i++){
        aBtn[i].className='';
        aDiv[i].className='';
    }
    aBtn[iNow].className='active';
    aDiv[iNow].className='show';
}
var timer=setInterval(f,1000);
oBox.onmouseover=function(){
    clearInterval(timer);
}
oBox.onmouseout=function(){
    timer=setInterval(f,1000);
}
分享到:
评论

相关推荐

    VC++课程设计:用生成的随机数画统计图(折线,柱形,条形,饼图)

    VC++课程设计:用生成的随机数画统计图(折线,柱形,条形,饼图),内含详细的设计过程及实验报告,经测试能运行,建议还是自己动手做做,不要说没有时间,其实只要你自己动手做出一个,你就会发现它并不难,不懂得记得baidu

    matlab数理统计数据分析:26 数理统计随机数的产生(含教学视频).zip

    1. **基本随机数生成**:MATLAB的`rand`函数可以生成[0,1)之间的均匀分布随机数,例如`rand(3,4)`会生成一个3行4列的随机数矩阵。通过调整范围,我们可以得到任何区间内的均匀分布随机数。 2. **正态分布随机数**:...

    matlab数理统计和数据分析及优化求解:matlab数理统计随机数的产生.zip

    MATLAB提供了一系列强大的函数来生成各种类型的随机数,这些随机数可以用于模拟实验、构建统计模型或者进行优化求解。下面将详细讨论MATLAB中关于数理统计随机数生成的相关知识点。 首先,MATLAB中的`rand`函数是最...

    matlab中使用rand函数产生随机数

    ### MATLAB中使用`rand`函数产生随机数 #### 一、`rand`函数的基本概念 在MATLAB中,`rand`函数被广泛用于生成伪随机数。这些随机数实际上是通过特定算法产生的,具有一定的可预测性和周期性。尽管如此,在大多数...

    matlab函数大全完整版.doc

    MATLAB 函数大全是 MATLAB 的一个全面且详细的函数手册,包含了 MATLAB 中的绝大多数函数,包括基本数学函数、三角函数、矩阵操作函数、随机数生成函数等。 一、MATLAB 基本数学函数 MATLAB 的基本数学函数包括: ...

    信息学奥赛一本通1184:明明的随机数

    信息学奥赛一本通1184:明明的随机数

    js随机数js随机数js随机数js随机数js随机数

    js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数js随机数...

    c++随机数产生函数

    如果没有设置随机数种子,rand()函数将自动设置随机数种子为1。rand()函数产生的随机数是假随机数字,每次执行时是相同的。若要生成不同的随机数,需要使用不同的值来初始化它。 srand()函数 srand()函数用来设置...

    matlab统计函数分享.pdf

    这些函数可以分为四大类:概率密度函数、累加分布函数、累加分布函数的逆函数和随机数生成器函数。 概率密度函数 概率密度函数(Probability Density Function,PDF)是指描述连续随机变量的概率分布的函数。...

    c51随机数的产生,开一个计数器,自动装入初值的模式

    ### C51随机数生成与计数器自动装入初值模式详解 #### 一、引言 在嵌入式系统开发中,随机数生成是一个非常实用的功能,尤其是在需要模拟不确定性或实现加密算法等场景下。本文将详细介绍如何在C51环境中利用...

    利用随机函数,产生随机数。隔N输出数。

    利用随机函数,产生随机数。隔N输出数。 利用随机函数,产生随机数。隔N输出数。

    matlab指令速查大全.pdf

    MATLAB基本函数速查大全 MATLAB是一种高性能的数学计算软件,广泛应用于科学计算、数据分析、算法开发等领域。下面是MATLAB中一些基本函数的速查大全: 数组操作函数: * ndims(A):返回数组A的维数 * size(A):...

    MATLAB函数速查手册 MATLAB函数对照表 Matlab函数参考手册 共42页.pdf

    MATLAB 函数速查手册 MATLAB 是一种高级编程语言和开发环境,主要应用于数学计算、数据分析、算法开发、应用程序开发等领域。MATLAB 提供了大量的内置函数,来帮助用户快速实现各种计算任务。下面是 MATLAB 函数速...

    MATLAB函数总结[参照].pdf

    MATLAB 函数总结收录了 MATLAB 中一些基本的数学函数、矩阵操作函数、随机数生成函数、统计分析函数等。 一、 MATLAB 中的矩阵操作函数 * ndims(A):返回矩阵 A 的维数 * size(A):返回矩阵 A 的大小 * length(A)...

    C语言产生随机数C语言产生随机数.doc

    * 如果未设置随机数种子,rand() 函数将自动设置种子为 1。 srand() 函数的使用: * srand() 函数用于设置随机数的种子值。 * srand() 函数的参数是一个 unsigned int 类型的值,范围在 0 到 65535 之间。 * 在...

    完整word版matlab函数大全最完整版.docx

    下面是 MATLAB 函数大全,涵盖了基本数学函数、三角函数、向量函数和随机数生成函数等。 一、基本数学函数 1. abs(x):纯量的绝对值或向量的长度 2. angle(z):复数 z 的相角(Phase angle) 3. sqrt(x):开平方 4...

    随机数 自动生成工具0323.xlsm

    做cpk报告时,想做合格的cpk报告,可以利用这工具,输入中差,上下偏差,cpk范围值,然后自动生成数据,进而导入minitab进行计算

    C语言学习-简易扫雷小程序 涉及二维数组、自定义函数、函数递归、随机数生成等 使用函数递归实现了空白区域的自动展开 .zip

    涉及二维数组、自定义函数、函数递归、随机数生成等。使用函数递归实现了空白区域的自动展开。游戏_扫雷C语言学习--简易扫雷小程序。涉及二维数组、自定义函数、函数递归、随机数生成等。使用函数递归实现了空白区域...

Global site tag (gtag.js) - Google Analytics