hasOwnproperty详细总结

hasOwnproperty详细总结hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。isPrototypeOf:是用来判断要检查其原型链的对象是否存在于指定对象实例中,是则返回true,否则返回falsefunctionperson(nickName,siteName){…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。

isPrototypeOf:是用来判断要检查其原型链的对象是否存在于指定对象实例中,是则返回true,否则返回false

function person(nickName,siteName){
             this.nickName=nickName;
             this.siteName;
             this.address='上海';
            }
            person.prototype.showAdmin = function() {
             alert(this.nickName+"是"+this.siteName+"的站长!")
            };
            person.prototype.showSite = function(siteUrl) {
             this.siteUrl=siteUrl;    //在原型上加一个私有的属性
             this.sayAge=function(){   //在原型上加一个私有的方法
                alert('20岁');
             }    
             return this.siteName+"的地址是"+this.siteUrl;
            };
            person.prototype.job='code';

            var p1=new person("脚本之家1","WEB前端开发");
            var p2=new person("脚本之家2","WEB前端开发");
            p1.age1="30";
            p1.age2;


            alert(p1.hasOwnProperty("nickName"));//true      //能够检测构造函数 模板函数里的属性和方法且该属性被赋值了 所以是true
            alert(p1.hasOwnProperty("siteName"));//false      //能够检测构造函数 模板函数里的属性和方法但是该属性没有被赋值,所以是false
            alert(p1.hasOwnProperty("address"));//true      //能够检测构造函数 模板函数里的属性和方法且被赋值,所以是true
            alert(p1.hasOwnProperty("age1"));//true       //能够检测p1上的属性且该属性被赋值了,所以是true
            alert(p1.hasOwnProperty("age2"));//false       //能够检测p1上的属性但是该属性没被赋值了,所以是false
            

            alert(p1.hasOwnProperty("showAdmin"));//false   //hasOwnProperty是不可以检测到原型链上的属性和方法
            alert(p1.hasOwnProperty("showSite"));//false    //hasOwnProperty是不可以检测到原型链上的属性和方法
            alert(p1.hasOwnProperty("job"));//false          //hasOwnProperty是不可以检测到原型链上的属性和方法


            alert(person.prototype.hasOwnProperty("showAdmin"));//true    //person.prototype上检测是否有showAdmin  弹出true
            alert(person.prototype.hasOwnProperty("job"));//true     //person.prototype上检测是否有job   弹出true
            alert(person.prototype.hasOwnProperty("siteUrl"));//false   //person.prototype上没有siteUrl   弹出false
            alert(person.prototype.hasOwnProperty("sayAge"));//false   //person.prototype上没有siteUrl   弹出false

            alert(person.prototype.isPrototypeOf(p1))//true
            alert(person.prototype.isPrototypeOf(p2))//true

Jetbrains全家桶1年46,售后保障稳定

 

        function person(nickName,siteName){
             this.nickName=nickName;
             this.siteName=siteName;;
            }
            person.prototype.showAdmin = function() {
             alert(this.nickName+"是"+this.siteName+"的站长!")
            };
            person.prototype.showSite = function(siteUrl) {
             this.siteUrl=siteUrl;    //在原型上加一个私有的属性
             this.sayAge=function(){   //在原型上加一个私有的方法
                alert('20岁');
             }    
             this.sayWork=function(){
                 this.work='打杂';
             };
             this.sex;

             return this.siteName+"的地址是"+this.siteUrl;
            };
            
            person.prototype.job='code';

            var p1=new person("脚本之家1","WEB前端开发");
            var p2=new person("脚本之家2","WEB前端开发");
            p1.age1="30";
            p1.age2;

              alert(p1.showSite("http://www.jb51.net/"));


            alert(p1.hasOwnProperty("siteUrl"));//true   //在上面一句调用了showSite原型方法,所以原型链里就创建了私有属性和方法且被赋值了,所以弹出true
            alert(p1.hasOwnProperty("sayAge"));//true   //在上面一句调用了showSite原型方法,所以原型链里就创建了私有属性和方法且被赋值了,所以弹出true
            alert(p1.hasOwnProperty("sayName"));//true   //p1调用showSite原型方法,所以原型链里就创建私有属性和方法且被赋值了,所以弹出true
            alert(p1.hasOwnProperty("work"));//false   //p1没有调用sayWork方法,所以就不会创建私有属性和方法(work),所以弹出false
            alert(p1.hasOwnProperty("sex"));//false   //p1调用showSite原型方法,所以原型链里就创建私有属性和方法但是sex没有被赋值,所以弹出false



             p1.sayAge();     //20岁
             p2.sayAge();    //会报错  p2.sayAge is not a function   因为p2没有调用showSite原型方法,所以没有创建p2的独有属性和方法,所以会报错

 

function person(nickName,siteName){
             this.nickName=nickName;
             this.siteName=siteName;;
            }
            person.prototype.showAdmin = function() {
             alert(this.nickName+"是"+this.siteName+"的站长!")
            };
            person.prototype.showSite = function(siteUrl) {
             this.siteUrl=siteUrl;    //在原型上加一个私有的属性
             this.sayAge=function(){   //在原型上加一个私有的方法
                alert('20岁');
             }    
             return this.siteName+"的地址是"+this.siteUrl;
            };
            person.prototype.job='code';

            var p1=new person("脚本之家1","WEB前端开发");
            var p2=new person("脚本之家2","WEB前端开发");
            p1.age1="30";
            p1.age2;

              //alert(p1.showSite("http://www.jb51.net/"));

            alert(p1.hasOwnProperty("siteUrl"));//false   //p1没有调用showSite原型方法,所以原型链里就不会创建私有属性和方法,所以弹出false
            alert(p1.hasOwnProperty("sayAge"));//false   //p1没有调用showSite原型方法,所以原型链里就不会创建私有属性和方法,所以弹出false
            



             p1.sayAge();     //20岁
             p2.sayAge();    //会报错  p2.sayAge is not a function   因为p2没有调用showSite原型方法,所以没有创建p2的独有属性和方法,所以会报错

 

转载于:https://www.cnblogs.com/tzz-ing/p/5072973.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234948.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • VS2017 安装 Microsoft Visual Studio Installer Project

    VS2017 安装 Microsoft Visual Studio Installer Project1.安装打包插件:MicrosoftVisualStudio2017安装程序项目2.联机查找下面的组件,然后安装,重启VS,进行插件安装3.新建安装项目,另外,有些人可能会想这么多安装类型,怎么选。因为我们这里说的Windows程序打包,输出文件格式为.exe或者.msi,大概看一下介绍就能知道,第一个和第四个是合适的。这两个又该怎么选呢?那其实第四个就是对一些属性多了些引导,最…

    2022年7月20日
    15
  • 外汇百科

    外汇百科
    外汇百科名片  外汇
    外汇是以外币表示的用于国际结算的支付凭证。国际货币基金组织对外汇的解释为:外汇是货币行政当局(中央银行、货币机构、外汇平准基金和财政部)以银行存款、财政部库券、长短期政府证券等形式所保有的在国际收支逆差时可以使用的债权。包括:外国货币、外币存款、外币有价证券(政府公债、国库券、公司债券、股票等)、外币支付凭证(票据、银行存款凭证、邮政储蓄凭证等)。
    目录简介外汇市场TransMarket集团FXSolutionsIFX与IFX(俗称FXSOL)?FX

    2025年10月19日
    3
  • 7k7k_leetcode 第一题

    7k7k_leetcode 第一题有 n 根长度互不相同的木棍,长度为从 1 到 n 的整数。请你将这些木棍排成一排,并满足从左侧 可以看到 恰好 k 根木棍。从左侧 可以看到 木棍的前提是这个木棍的 左侧 不存在比它 更长的 木棍。例如,如果木棍排列为 [1,3,2,5,4] ,那么从左侧可以看到的就是长度分别为 1、3 、5 的木棍。给你 n 和 k ,返回符合题目要求的排列 数目 。由于答案可能很大,请返回对 109 + 7 取余 的结果。示例 1:输入:n = 3, k = 2输出:3解释:[1,3,2], [2,3,

    2022年8月11日
    6
  • pytest重试_连接重连失败是什么意思

    pytest重试_连接重连失败是什么意思安装:pip3installpytest-rerunfailures重新运行所有失败用例要重新运行所有测试失败的用例,请使用–reruns命令行选项,并指定要运行测试的最大次数:$py

    2022年7月28日
    6
  • PHPer面试指南-协议 篇

    PHPer面试指南-协议 篇

    2022年2月11日
    36
  • Solr集成Tomcat

    Solr集成Tomcat

    2021年5月30日
    104

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号