手记

JavaScript学习笔记

1、javascript的面向对象

1.1、创建对象的方式

方式一:使用object对象搞定

<script type="text/javascript">

        //创建一个对象

        var object = new Object();

        //在js中对象可以动态的添加属性和方法

        object.name = "张三";

        object.age = 15 ;

        //动态添加方法

        object.sayHello=function(){

            console.log(this.name,this.age);

        };

        //动态删除某个对象的方法或者属性

        delete object.sayHello;

        //object.sayHello();

        console.log(object);

</script>

方式二:json格式

json的格式:

mark

 var stu={

                name:"zhangsan",

                addr:"南京",

                age:15,

                say:function () {

                    console.log(this.name,this.age,this.addr);

                }

        }

        stu.say();

json数组:

mark

value的变化多端

mark

<script type="text/javascript">

        var students=[

            {

               name:"关羽",

               type:"坦克"

            },

            {

                name:"阿珂",

                type:"刺客"

            },

            {

                name:"老亚瑟",

                type:"坦克"

            },

            {

                name:"王昭君",

                type:"法师"

            }

        ]

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

            console.log(students[i].name,students[i].type)

        }

    </script>

方式三:工厂方法

function createObject(name,age){

    var object = new Object();

    object.name = name;

    object.age=age;

    object.say=function(){

        console.log(this.name,this.age);

    }

    return object ;

}

//创建对象

var object1 = createObject("张三",15);

//调用方法

object1.say();

//创建对象

var object2 = createObject("李四",20);

//调用方法

object2.say();

方式四:构造函数

题外话

function Person(){

            console.log(this.name,this.age);

}

//函数的普通调用方式

window.name="hello";

window.age=15;

Person();

Person();

默认直接调用函数实际上调用的对象是window对象

创建对象

<script type="text/javascript">

        function Person(name,age){

            this.name = name

            this.age = age;

            this.say=sayInfo;

        }

        function sayInfo(){

            console.log(this.name,this.age);

        }

        //采用new的方式调用实际上省略了创建对象和返回对象的过程

        var p1 = new Person("张三",15);

        var p2 = new Person("李四",20);

        p1.say();

        p2.say();

    </script>

方式五:原型模式

<script type="text/javascript">

        //构造中一般放属性

        function Person(name,age){

            this.name = name ;

            this.age = age ;

        }

        //通过prototype属性,我们可以原型上加上方法和属性

        Person.prototype.say=function(){

            console.log(this.name,this.age);

        };

        Person.prototype.sayWorld=function(){

            console.log("helloworld");

        };

        var p1 = new Person("zhangsan",15);

        var p2 = new Person("lisi",16);

        console.log(p1);

        console.log(p2);

        p1.sayWorld();

        p2.sayWorld();

    </script>

1.2、继承

1.2.1、对象冒充方式

利用的原理就是动态添加方法,转移this的指向

<script type="text/javascript">

        function Parent(name) {

            console.log(this);

            this.name = name ;

        }

        function Son(name,age) {

            //Parent(name);

            this.method=Parent;

            this.method(name);

            //将这个method方法在动态删除掉

            delete this.method;

            //子类特有的

            this.age = age ;

        }

        var s = new Son("张三",15);

        console.log(s.name,s.age);

    </script>

1.2.2、apply和call方式

call方法介绍

call 方法:调用一个对象的一个方法,以另一个对象替换当前对象。

call([thisObj[,arg1[, arg2[,   [,.argN]]]]])

参数

thisObj:可选项。将被用作当前对象的对象。

arg1, arg2,  , argN:可选项。将被传递方法参数序列。

使用call方法来改写上面的案例

 <script type="text/javascript">

        function Parent(name) {

            console.log(this);

            this.name = name ;

        }

        function Son(name,age) {

            Parent.call(this,name);

            //子类特有的

            this.age = age ;

        }

        var s = new Son("张三",15);

        console.log(s.name,s.age);

   </script>

apply:和call用法基本一致

apply 方法:应用某一对象的一个方法,用另一个对象替换当前对象。

apply([thisObj[,argArray]])

参数:thisObj可选项。将被用作当前对象的对象。

argArray:可选项。将被传递给该函数的参数数组。

apply方式来改写案例

<script type="text/javascript">

        function Parent(name) {

            console.log(this);

            this.name = name ;

        }

        function Son(name,age) {

            Parent.apply(this,[name]);

            //子类特有的

            this.age = age ;

        }

        var s = new Son("张三",15);

        console.log(s.name,s.age);

</script>

1.2.3、采用原型+apply的混合方式实现继承

<script type="text/javascript">

        function Parent(name) {

            console.log(this);

            this.name = name ;

        }

        //父类的方法

        Parent.prototype.sayHello=function(){

            console.log("helloworld");

        }

        function Son(name,age) {

            Parent.apply(this,[name]);

            //子类特有的

            this.age = age ;

        }

        //将父类原型上的属性和方法移植子类中

        Son.prototype=new Parent();

        var s = new Son("张三",15);

        console.log(s.name,s.age);

        s.sayHello();

 </script>

补充知识点:

callee :返回正被执行的 Function对象,也就是所指定的 Function 对象的正文

function factorial(n){

            if (n <= 0)

                return 1;

            else

                return n * arguments.callee(n - 1)

 }

console.log(factorial(5));

eval():执行eval参数中js代码

 eval("var mydate = new Date();");

 alert(mydate);

练习:

编写一个形状类,它是一个父类

然后编写一个长方形类,要求求出长方形的周长

在编写一个三角形类,求出三角形的周长

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        function Shape(width){

            this.width=width;

        }

        Shape.prototype.getLength=function(){

            console.log('正在获取长度');

        };

        function Rectangle(width,height){

            Shape.call(this,width);

            this.height = height;

        }

        Rectangle.prototype = new Shape();

        Rectangle.prototype.getLength=function(){

            return (this.width+this.height)*2;

        };

        //创建一个长方形对象

        var re = new Rectangle(10,20);

        console.log(re);

        console.log(re.getLength());

        //对象的__proto__恒等于Rectangle.prototype属性

        //console.log(re.__proto__===Rectangle.prototype);

        console.log(1=="1");

        //先比较数据类型,如果数据类型不一样,就直接over(false)

        console.log(1==="1");

        //创建一个三角形的类

        function Triangle(width,height,c){

            Shape.call(this,width);

            this.height=height;

            this.c = c ;

        }

        Triangle.prototype = new Shape();

        Triangle.prototype.getLength = function(){

            return this.width+this.height+this.c;

        }

        var tr = new Triangle(1,2,3);

        console.log("三角形的长度为:"+tr.getLength());

    </script>

</head>

<body>

</body>

</html>

©著作权归作者所有:来自51CTO博客作者mirindaRain的原创作品,如需转载,请注明出处,否则将追究法律责任


0人推荐
随时随地看视频
慕课网APP