想成为JS大神必须会的东西

定制对象

var house = {
        rooms: 7,
        sharedEntrance: false,
        lock:function(){},
        unlock:function(){}
    };
    alert(house.rooms);
    alert(house.sharedEntrance);
    
    house.rooms = 8;
    alert(house.rooms);

function Accommodation(){};

    var house = new Accommodation();  //用new创建出来的对象都被称作是这个函数所示结构的对象实例
    var apartment = new Accommodation();  //创建对象的过程就叫做模板实例化的过程
    
    
    //找出对象的构造器
    alert(house.constructor === Accommodation);  //true
    //还可以用 instanceof 来完成
    alert(apartment instanceof Accommodation);

公有私有保护的属性和方法

var Accommodation = (function(){
        //定义“类”的构造函数,因为处在一个新的函数内,我们也切换到一个新的作用域中,所以可以使用与保存函数返回值得那个变量相同的名字
        function Accommodation(){};
        //此处定义的所有变量都是私有的,为了区分加了_,这些变量在当前作用域之外不能用。
        var _isLocked = false,
        _isAlarmed = false,
        _alarmMessage = "Alarm activated";
        
        //仅在当前作用域中定义的函数也都是私有的
        function _alarm(){
            _isAlarmed = true;
            alert(_alarmMessage);
        }
        
        function _disableAlarm(){
            _isAlarmed = false;
        }
        
        //所有定义在原型上的方法都是公有的,当我们在此处创建类在闭包结束处被返回后,就可以在当前作用域之外访问这些方法了
        Accommodation.prototype.lock = function(){
            _isLocked = true;
            _alarm();
        }
        
        Accommodation.prototype.unlock =  function(){
            _isLocked = true;
            _disableAlarm();
        }
        
        //定义一个getter函数来对私有变量_isLocked的值进行只读访问——相当于把该变量定义为“受保护的”
        Accommodation.prototype.getIsLocked = function(){
            return _isLocked;
        }
        
        //定义一个setter函数来对私有变量_alarmMessage进行只写访问——相当于将其定义为“受保护的”
        Accommodation.prototype.setAlarmMessage = function(message){
            _alarmMessage = message;
        };
        //返回在这个作用域中创建的“类”,使之在外层作用域中即后面代码的所有位置都可用。只有共有的属性和方法是可用的。
        return Accommodation;
    }());
    var house = new Accommodation();
    house.lock();
//  house._alarm(); //报错
    alert(house._isLocked);  //undefined
    console.log(house.getIsLocked());  //true
    house.setAlarmMessage("The alarm is now activated!");
    house.lock(); //"The alarm is now activated!"

一个用于简化其他“类”创建的基“类”

//定义一个名为Class的对象,该对象有一个create()方法用于创建新的“类”。我们用闭包来维护内部函数;
    //避免公开暴露这些函数
    var Class = (function(){
        //调用create()方法时,它将根据一个对象直接量来定义并且返回一个新的“类”,该对象直接量为这个“类”的原型提供了各种公有属性和方法。
        //一个名为initialize()的方法将被作为构造函数来执行。如果代表父“类”的可选参数paraentPrototype被传入,则新创建的“类”将成为该父“类”的子类
        function create(classDefinition,parentPrototype){
            //定义新“类”的构造函数,如果classDefinition对象直接量包含initialize()方法,则在构造函数中使用该方法
            var _NewClass() = function(){
                if(this.initialize && typeof this.initialize === 'function'){
                    this.initialize.apply(this,arguments);
                }
            },
            _name;
            //(在继承其他“类”时)如果传入一个parentPrototype对象
            //则子类将继承parentPrototypee的所有属性和方法
            if(parentPrototype){
                _NewClass.prototype = new parentPrototype.constructor();
                
                for (_name in parentPrototype) {
                    if (parentPrototype.hasOwnProperty(_name)) {
                        _NewClass.prototype[_name] = parentPrototype[_name];
                    }
                }
            }
            
            //通过定义一个函数来创建闭包,然后在闭包中返回另一个函数来替代传入的函数
            //将传入的函数包装起来,并为当前对象提供一个_parent()方法,
            //以支持父“类”中同名方法的访问,这样就实现了多态的支持
            
            function polymorph(thisFunction,parentFunction){
                return function(){
                    var output;
                     this._parent = parentFunction;
                     
                     output = thisFunction.apply(this,arguments);
                     
                     delete this._parent;
                     
                     return output;
                };
            }
            
            //将作为参数传入的“类”定义应用到新创建的“类”上,
            //覆盖所有parentPrototype中已存在的属性和方法
            for (_name in classDefinition) {
                if (classDefinition.hasOwnProperty(_name)) {
                    //如果正在利用多态,即创建和父“类”方法同名的新方法,
                    //我们希望提供一种在子“类”方法中调用父“类”同名方法的简单方式
                    if (parentPrototype && parentPrototype[_name] && typeof classDefinition[_name] === 'function') {
                        _NewClass.prototype[_name] = polymorph(classDefinition[_name],parentPrototype[_name]);
                    }else{
                        //如果不需要多态,则直接将calssDefinition对象直接量中的项映射到新“类”的原型即可
                        _NewClass.prototype[_name] = classDefinition[_name];
                    }
                }
            }
            
            //确保构造函数属性设置正确,不管是否继承
            //(以防classDefinition对象直接量包含名为constructor的属性方法)
            _NewClass.prototype.constructor = _NewClass;
            
            //为新创建的“类”自身定义一个extend()方法,指向私有的extend()函数,这个函数定义在下面,
            //我们通过此方法可以将当前“类”作为父“类”来创建一个新的子类
            _NewClass.extend = extend;
            return _NewClass;
        }
        
        //extend()与create()方法相同,不过隐含了一个额外的参数,即用来进行继承的父“类”的原型
        function extend(classDefinition){
            return create(classDefinition,this.prototype);
        }
        
        //用相同的名字将私有的create()方法暴露
        return {create: create};
    }());

对象方法

var personalDetails = {
        name:"Den Odell",
        email: "den.odell@me.com"
    };
    
    console.log(Object.isExtensible(personalDetails));//true
    
    //阻止对personalDetails对象进行扩展
    Object.preventExtensions(personalDetails);
    
    console.log(Object.isExtensible(personalDetails));//false
    
    //尝试为personalDetails对象添加一个新属性
    personalDetails.age = 35;  //如果开启严格模式就会报错
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,951评论 6 13
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,650评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,050评论 25 707
  • 对于季节来说冬天已经过去,春天的脚步已经来临,只是还有一点点冷而已。但对于整个经济形势,大部份的人还是在...
    黄健歌阅读 1,611评论 1 1
  • 今天想跟大家分享一下我的大学兼职经历。 今天想写的是生活中你遇到的那形形色色的人,仔细观察发现你会从不同的人身上学...
    已北阅读 1,395评论 0 1