JS中级面向对象

面向对象:

JS一开始就是写网页特效 ,面向过程的,作者发现这样写不哈,代码重复利用率太高计算机内存消耗太大,网页性能很差。作者 就收到java和c你的影响 ,望面向对象烤漆。

Js天生有一个Object,但他没有面向对象的特征(封装,继承,多态)。最后研究出了构造函数。

构造函数最终目的是生成对象。

我们把封装的那个函数叫 类

类里面的属性是私有的。

类原型上的属性是公有的,可继承的。

  1. 类身上天生自带一个prototype的属性,属性是对象
  2. Prototype对象天生有一个constructor属性,属性值就是类本身
  3. 实例天生有一个__proto__ 指向你自己类的原型
  4. 原型链主要针对对象的属性来说的

    作用域链主要针对变量来说的

  5. var a和a的区别

    没有带var的变量就不能存放到内存地址中。就没有变量提升这种说法了。相当于给window加了一个属性window.a。

    带var 可以存放在内存地址中,有变量提升,同时也相当于给window加了一个属性window.a

  6. 函数:

    函数在调用的时候,会形成一个私有作用域,内部的变量不会被外面访问,这种保护机制叫闭包。这就意味着函数调用完毕,这个函数形成的栈内存会被销毁
  7. var c = fun(0).fun(1);  c.fun(2); c.fun(3);//undefined,?,?,?

    基类Object的子类有

    Function  Array  Number  Boolean  String  Date  Math  RegExp

    函数 数组 数字 布尔 字符串 日期 算数 正则 都是类。本质都是函数。

    String类

    定义字符串的方法

    Var st=new String(“hello world”)  

    简写

    Var st=”hello world”

    1. 字符串的加号运算   +   仅仅就是拼接  这种方法 叫字符串拼接。
    2. 字符串prototype上的方法

    (1)       charAt()  返回在指定位置的字符   var s=st.charAt(2)

    (2)       Concat()  链接两个或多个字符串,并返回新的var s=st.concat(sd,"hello wolrd");

    (3)       indexOf()  返回某个字符串在字符串中首次出现的位置,没有返回-1

  8. (1)       lastIndexOf()  功能和indexOf一样 不过是从后往前

    (2)       match() 

    (3)       Search()

    (4)       Replace()

    (5)       Slice() 截取字符串中的一部分

       前闭后开 包含2但是不包含7

    (6)       Split()  将字符串按某种形式分割成数组

     

    (7)       substr() 也是截取 和slice有点区别

     

    (8)       substring()  跟slice一样

    (9)       toLowerCase() 将字符串的中字符都变成小写

    (10)   toUpperCase() 将字符串中的字符都变成大写

    (11)   trim()  去掉字符串两端的空白

    补充

     

    每个函数都天然自带一个return。如果写return 返回什么就是什么,如果不写就是undefined

    类 他的本质也是函数,里面也有return 但默认是object,如果强制return一个值,不会造成影响,如果return是个对象,就会造成影响

  9. Array  数组这个类

    数组的定义

    Var arr=new Array(“12”,”zhangsan”)

    简写

    Var arr=[12,”张三”]

    基本的方法

    1.Push() 在数组的结尾处添加一个新元素。返回值是数组长度

     

    2.unshift()在开始处填加一个新元素。返回值是数组长度

    1. pop() 删除数组中的最后一个元素。返回的是删除的那个元素

     

    4.shift()  删除数组中的第一个元素。返回的是删除的那个元素

     

    5.slice() 截取数组中的一部分,并返回新的数组。对原来的数组没有影响

     

    6.splice() 在数组中添加或删除元素。

     

    从第三个开始向后删除一个 添加三个新的

    7.sort() 给数组中的元素排序

    8.reverse() 反转数组中元素的顺序

    9.toString() 将数组转换成字符串格式的数组,并返回结果

     

    10.concat()  合并多个数组,并返回新的值

     

    11.indexOf()   检索数组中的元素,并返回他所在的位置,没有就是-1

     

    数组经典面试题

    数组去重

    //数组去重

    var arr=[12,45,12,23,12,23];

    var ass=[];

    for(var i=0;i<arr.length;i++){

        if(ass.indexOf(arr[i])==-1){

            ass.push(arr[i])

        }

    }

    console.log(ass)

     

 

posted @ 2018-12-02 23:22  安文莹  阅读(92)  评论(0编辑  收藏  举报