zoukankan      html  css  js  c++  java
  • javascript中的面向对象—— 学习1

    面向对象:Object Oriented(OO)

      一切事物皆对象,通过面向对象的方式,将显示世界的事物抽象成对象,将显示世界中的关系抽象成类、继承,帮助人们实现对显示世界的抽象与数字建模;——百科

    一、基础知识点:

    1、面对对象的语言都有一个标志就是都有类的概念,可以通过类创建多个具有相同属性和方法的对象;

    2、ECMA-262中没有类的概念

    3、ECMA-262中定义为:“无序属性的集合,其属性可以包含基本的属性值、对象或者函数”

    4、理解对象:创建对象

    //创建对象最简单的方式就是创建一个Object对象,再对其添加属性和方法(早期使用此方法)
    var person = new Object()
    person.name="Nicholas";
    person.age= 56;
    person.job="Software Engineer";
     person.SayHai=function (){
    	 alert(person.name)
     }
     
     
     //以对象字面量的形式创建对象(达到的目的是一样的)
     var person={
    	 name="Nicholas";
    	 age=34;
    	 job="Software Engineer";
    	 SayHai:function{
    		 alert(person.name);
    	 }
    	 Ask:function{
    		 alert("Hello World");		 
    	 }
     }//注意此方法中是如何创建对象方法的
    

      

    二、属性类型

    1、数据属性

    //默认都为true 
     [[Configurable]]//表示能否通过delete删除属性从而重新定义属性、能否修改属性特性、或能否把属性改为访问器属性
     [[Enumerable]]//能否通过for-in循环返回属性
     [[Writable]]	//能否修改属性的值
     [[Value]]		//包含这个属性的数据值
     
    

      要修改属性默认的特性,必须用ECMAScript5的Object.defineProperty()方法

     var person ={}
          Object.defineProperty(person,"name",{
            Writable:false,
            Value:"Nicholas"
    });
    

      注:以上writable:false; 就是配置name属性不可修改   在严格模式下修改回报错

    var person={}
    	Object.defineProperty(person,"name",{
    		Configurable:false,
    		Value:"Nicholas";
    	});
    	delete person.name;
    	alert(person.name);//Nicholas
    

      注:以上Configurable:false; 所以delete删除  person.name在非严格模式下不起作用,在严格模式下回报错;

    ☆☆☆☆☆  可以多次Object.defineProperty()方法修改同一个属性,但在configurable特性设置了false之后在调用、修改就会有限制了(报错)

    2、访问器属性

    三、定义多个属性

    //定义多个属性
    
    var book={};
    Object.defineProperties(book,{
    	_year:{
    		Writable:true,
    		Value:2004
    	},
    	
    	edition:{
    		Writable:true,
    		Value:1
    	},
    	
    	year:{
    		get:function(){
    			return this._year;
    		},
    		
    		set:function(){
    			if(newValue > 2004){
    				this._yeay=newValue;
    				this.edition+=newValue - 2004
    			}
    		}
    	}
    });

      

    四、读取属性的特性;

    Object.getOwnPropertyDescriptor()  // 方法
    

      

  • 相关阅读:
    【NOI1999、LOJ#10019】生日蛋糕(搜索、最优化剪枝、可行性剪枝)
    【NOI2016】区间
    【CodeForces688A】Opponents
    「LOJ10150」括号配对
    HDU6444(子段和、分情况比较)
    牛客练习赛41E(球的体积并)
    Codeforces 1154G(枚举)
    POJ1830(异或高斯消元)
    Codeforces 1114F(欧拉函数、线段树)
    牛客小白月赛13 G(双向搜索)
  • 原文地址:https://www.cnblogs.com/zhuyucun/p/6181115.html
Copyright © 2011-2022 走看看