小心 ------ javascript(5)

2024-08-25 12:48
文章标签 java script 小心 ------

本文主要是介绍小心 ------ javascript(5),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在JavaScript中创建的每个函数都有一个prototype(原型)属性,这个属性是一个指针(指向一个对象),而这个对象的用途是包含可以由特定类型的所有实例共享的属性和方法

使用原型对象的好处是可以让所有对象实例共享它所包含的属性和方法

function JaXiang() {}
JaXiang.prototype.location = "Luo Yang";JaXiang.prototype.age = 5000;JaXiang.prototype.writeLocation = function () {return this.location;
};
var oJaXiangL = new JaXiang();var oJaXiangY = new JaXiang();oJaXiangL.writeLocation();oJaXiangY.writeLocation();

虽然oJaXiangL和oJaXiangY这两个实例都不包含属性和方法,但却可以访问age和location属性并且调用writeLocation方法,这是通过查找对象属性的过程来实现的,每当代码读取某个对象的某个属性时,都会执行一次搜索,目标是具有给定名字的属性。搜索首先从对象实例本身开始。如果在实例中找到了具有给定名字的属性,则返回该属性的值;如果没有找到,则继续搜索指针指向的原型对象,在原型对象中查找具有给定名字的属性。如果在原型对象中找到了这个属性,则返回该属性的值。

使用hasOwnProperty()方法可以检测一个属性是存在于实例中,还是存在于原型中。这个方法(不要忘了它是从Object 继承来的)只在给定属性存在于对象实例中时,才会返回true。  

 

function JaXiang() {}
JaXiang.prototype.location = "Luo Yang";JaXiang.prototype.age = 5000;JaXiang.prototype.writeLocation = function () {return this.location;
};
var oJaXiangL = new JaXiang();var oJaXiangY = new JaXiang();//oJaXiangL.writeLocation();//oJaXiangY.writeLocation();oJaXiangL.location = null;oJaXiangY.age = 5001;

虽然可以通过对象实例访问保存在原型中的值,但却不能通过对象实例重写原型中的值。如果我们在实例中添加了一个属性,而该属性与实例原型中的一个属性同名,那我们就在实例中创建该属性,该属性将会屏蔽原型中的那个属性。

function JaXiang() {}
JaXiang.prototype.location = "Luo Yang";JaXiang.prototype.age = 5000;JaXiang.prototype.writeLocation = function () {return this.location;
};
var oJaXiangL = new JaXiang();var oJaXiangY = new JaXiang();//oJaXiangL.writeLocation();//oJaXiangY.writeLocation();oJaXiangL.location = null;oJaXiangY.age = 5001;delete oJaXiangL.location;delete oJaXiangY.age;

 

当为对象实例添加一个属性时,这个属性就会屏蔽原型对象中保存的同名属性;换句话说,添加这个属性只会阻止我们访问原型中的那个属性,但不会修改那个属性。即使将这个属性设置为null,也只会在实例中设置这个属性,而不会恢复其指向原型的连接。不过,使用delete 操作符则可以完全删除实例属性,从而让我们能够重新访问原型中的属性。

 

function JaXiang() {}
JaXiang.prototype.location = "Luo Yang";var oJaXiangL = new JaXiang();JaXiang.prototype.age = 5000;JaXiang.prototype.writeLocation = function () {return this.location;
};     JaXiang.prototype = {newLocation : "New Luo Yang",newAge: 10000,newWriteLocation : function () {return this.location;}
};var oJaXiangY = new JaXiang();

使用(JaXiang.prototype.属性名 = 属性值;)这种方法随时为原型添加属性和方法,并且修改能够立即在所有对象实例中反映出来(即使是先定义变量再添加也可以);但如果是使用了(JaXiang.prototype= {属性名 = 属性值})这种语法重写整个原型对象后,之前创建的对象与之后创建的对象并不一样。

这篇关于小心 ------ javascript(5)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105593

相关文章

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

Java文件与Base64之间的转化方式

《Java文件与Base64之间的转化方式》这篇文章介绍了如何使用Java将文件(如图片、视频)转换为Base64编码,以及如何将Base64编码转换回文件,通过提供具体的工具类实现,作者希望帮助读者... 目录Java文件与Base64之间的转化1、文件转Base64工具类2、Base64转文件工具类3、

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

如何使用Spring boot的@Transactional进行事务管理

《如何使用Springboot的@Transactional进行事务管理》这篇文章介绍了SpringBoot中使用@Transactional注解进行声明式事务管理的详细信息,包括基本用法、核心配置... 目录一、前置条件二、基本用法1. 在方法上添加注解2. 在类上添加注解三、核心配置参数1. 传播行为(

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程

《在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程》本文介绍了在Java中使用ModelMapper库简化Shapefile属性转JavaBean的过程,对比... 目录前言一、原始的处理办法1、使用Set方法来转换2、使用构造方法转换二、基于ModelMapper

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例