0710-JS基础

判断引用数据类型的类

  • 1,constructor 可以检测出当前具体属于哪个类

  • 2,instanceof 断某个对象是否属于哪个类?返回的是个布尔值

  • 3.console.log(Object.prototype.tostring.call())可以打印出对象的详细信息

  • 4.typeof只能检测基本数据类型,不能具体检测引用数据类型。

函数function

函数的定义阶段

  • 1, 定义函数相当于开辟了一个内存空间,给这个空间起个名字。
  • 2,把函数体内的所有js代码作为字符串存在内存空间中
  • 3,把内存空间名赋值给变量名

函数的调用

  • 1,形成一个私有作用域
  • 2,把内存中的字符串拿出来作为js代码
  • 函数名();
  • 函数只定义,不调用,什么都不会发生

关于函数的返回值

  • 返回值:return;
  • undefined出现的情况
    • 1:函数没有写return;
    • 2:函数写了return,但是没有赋值;
    • 3:只定义了形参,但是没有传实参;
    • 4:声明了变量,但是对变量没有赋值
  • arguements.callee 打印出函数本身。

函数的有名函数和匿名函数

  • 1:有名函数:给元素的某个属性绑定一个函数表达式。
  • 2:匿名函数:函数自己调用自己。

闭包

  • 1:当函数被调用的时候,形成一个私有作用域,保护里边的变量不收干扰,函数的这种保护机制,叫做闭包。
  • 2:子函数可以使用父函数的私有变量。

数组的增删改除

  • 增加 .push在数组末尾增加项 参数:有 返回值:数组长度 原始数组是否改变:是
    • ary.push('sss')
  • 删除 .pop删除数组末尾项 参数:无
    返回值:被删除的内容 原始数组是否改变:是
    • ary.pop()
  • 给开头增加 unshift()
    功能:给数组增加一个或多个
    参数:有,一个或多个
    返回值:数组的长度
    原始数组是否改变:是
    • aty.unshift('');
  • splice
    • 参数是一个的时候,从参数开始后边的全部删除,返回删除的参数以新数组的方式存在
    • 参数是两个的时候 splice(2,3)
      • 从索引开始,删除3个
      • ary.shift()

数组克隆

  • slice(n,m)从索引n克隆到m。但是包前不包后。

数组拼接

  • 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用来改变callback中的this指向;
    • forEach 没有返回值,但是map有返回值
  • ary.map() 和forEach相似,除了返回值不一样

选项卡里面,自动计算选项卡宽度

 oWrap.style.width=aBtn.length*aBtn[0].offsetWidth+'px';

总结

  • 给数组末尾增加一项有哪些方法?
    • push()
    • splice(ary.length,0,'xxx')
    • ary[ary.length]=xxx;

扩展题

  • 删除数组最后一项有几种方法?
    • pop()
    • splice(ary.length-1,1)
  • 数组克隆有几种方法?
    • .slice()
    • .slice(o)
    • .concan()
  • 请实现数组去重?
    • 利用对象不重名的特性;2个 重点
  • tab(id,设置默认选中项);注意,第二个参数可传可不传,如果传了,按照第二个参数显示默认项,如果没传,默认选中第一项; 重点
 if ((h>=1)&&(h<=aBtn.length)) {
            aBtn[h-1].className = 'on';
            aDiv[h-1].className = 'show';
        }
        else {
            aBtn[0].className = 'on';
            aDiv[0].className = 'show';
        }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容