美文网首页
2019-03-19 js practice three

2019-03-19 js practice three

作者: 婷婷玉 | 来源:发表于2019-03-19 11:35 被阅读0次

    数据类型检测有4种方法

    • typeof 主要用来检测基本数据类型,不能具体检测出引用数据类型
    • constructor 可以检测出当前这个对象具体属于哪个类
    • instance of (obj instance of Object) 判断某个对象是否属于某个类,返回的应该是个布尔值
    • Object.prototype.toString.call() 可以打印出对象的详细信息;

    函数的基础知识

    • 函数由两部分构成
      • 函数的定义阶段
      function 函数名(){
      
      }
      
      • 函数的调用:函数名();
    • 函数只定义,不调用,什么也不会发生

    函数定义3步骤:

    1、开辟一个内存空间,给这个空间起个名字
    2、把函数体内所有JS代码,作为字符串,存在这个内存空间中
    3、把空间地址,赋值给函数名;

    函数调用2步骤

    1、形成一个私有作用域;
    2、把内存中的字符串,作为JS代码来执行

    关于函数的返回值

    • 返回值:return
    • undefined出现的情况:
      • 函数没有写return,返回的就是undefined;
      • 函数写了return,但没有赋值,返回的还是undefined;

    参数

    • 参数包含实参和形参;
      • 形参:形参在函数定义阶段
      • 实参:在函数调用阶段
      • 定义形参,但没有传实参?拿到的是undefined;
      • arguments.callee:拿到的是当前函数本身;
    • 函数包含有名函数和匿名函数;
      1:匿名函数:给元素的某个属性绑定一个函数表达式;
      2:匿名函数:函数自己调用自己;

    闭包:

    1:当函数被调用的时候,会形成一个私有作用域,保护里面的变量不受外界的干扰,函数的这种保护机制,叫做闭包;
    2:自函数可以使用父函数的私有变量;
    

    数组常用的方法

    增加,删除和替换

    • 增加 push()
      • 功能:给数组末尾增加一个或多个
      • 参数:有
      • 返回值:数组的长度
      • 原始数组是否改变:是
    • 删除 pop()
      • 功能:删除数组最后一个
      • 参数:无
      • 返回值:被删除的内容
      • 原始数组是否改变:是
    • 给开头增加 unshift()
      • 功能:给数组开头增加一个或多个
      • 参数:有,一个或多个
      • 返回值:数组的长度
      • 原始数组是否改变:是
    • 从数组开头删除 shift()
      • 功能:给数组开头删除一个或多个
      • 参数:无
      • 返回值:被删除内容
      • 原始数组是否改变:是
    • 操作数组的任何位置,进行增加,删除和替换 splice
      • 删除
        • 参数是一个时,代表从当前索引,一直删完
        • 参数是两个时 splice(2,3)
          • 从索引2开始,删除3个
          • 被删除内容以一个新数组的形式返回
      • 增加
        • 参数 三个 arr.splice(2,0,'a','b')
          • 从索引2开始,增加'a','b',删除0个,增加的内容插入到索引2的前面;
          • 返回值:无
          • 原始数组是否改变:是
      • 替换
        • 参数 三个 ary.splice(2,2,'aa','bb')
          • 从索引2开始,删除2个,增加'a','b'插入到索引2的位置
          • 返回值:被删除的内容,以一个新数组的形式返回;
          • 原始数组是否改变:是

    数组克隆和拼接

    • slice(n,m) 从索引n克隆到索引m,但是包前不包后;
      • 原始数组不变
      • 题:克隆第n项到第m项[n,m],包含n和m,请用数组的一个方法来实现;
        • ary.slice(n-1,m)
      • 克隆 ary.slice(0) / ary.slice();
    • concat 拼接
      • ary1.concat(ary2,ary3);
      • 克隆 ary.concat() 不要传参;

    数组的翻转和排序

    • 数组的翻转 reverse()
      • 返回值:就是翻转后的新数组
      • 原始数组发生改变;
    • 数组的排序 sort()
    ary.sort(function(n,m){
        return(n-m);//从小到大排序
        return(m-n)//从大到小排序
    })
    

    数组转字符串

    • ary.toString() 把数组转成以逗号分隔的字符串;
    • ary.join('拼接形式')
      • 配合eval()可以实现数学运算

    数组常用但不兼容的方法

    • ary.indexOf() 查找数组中是否有某项,如果有返回对应内容的索引,如果没有返回-1;
    • ary.forEach()
      • forEach 接收两个参数,一个是callback,thisArg
      • callback 接收三个参数 1)item 2) index 3) input
      • thisArg 用来改变callb中的this指向;
      • forEach 没有返回值,但map有返回值
    • ary.map()

    相关文章

      网友评论

          本文标题:2019-03-19 js practice three

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