JavaScript基础学习(四)—Object
一、Object的基本操作
1.对象的创建
在JavaScript中,创建对象的方式有两种:构造函数和对象字面量。
(1)构造函数
var person = new Object();
person.name = "Tom";
person.age = 22;
person.say = function(){
alert("Hello");
}
(2)对象字面量
var person = {
name : "Tom",
age : 22
}
2.对象属性和方法的删除
可以使用delete操作符。
var person = {};
person.name = "Tom";
person.age = 20;
person.say = function(){
alert("Hello!!!");
}
//delete操作符删除对象的属性和方法
delete person.name;
delete person.say;
alert(person.age); //20
alert(person.name); //undefined
alert(person.say); //undefined
3.对象的遍历
可以使用for in枚举遍历。
var person = {};
person.name = "Tom";
person.age = 20;
person.say = function(){
alert("Hello!!!");
}
//遍历对象
for(var attr in person){
alert(attr + " = " + person[attr]);
}
二、Object的属性和方法
1.constructor属性
constructor属性是保存当前对象的构造函数,前面的例子中,constructor保存的就是Object方法。
var person = {};
person.name = "Tom";
person.age = 20;
person.say = function(){
alert("Hello!!!");
}
/*
* constructor: 保存对象的创建函数
* function Object() {
* [native code]
* }
*/
alert(person.constructor)
2.hasOwnProperty(propertyName)方法
hasOwnProperty()方法接收一个字符串参数,该参数表示属性名称,用来判断该属性是否在当前对象实例中,而不是在对象的原型链中。
var person = {};
person.name = "Tom";
person.age = 20;
person.say = function(){
alert("Hello!!!");
}
//hasOwnProperty(propertyName): 用于检测给定的属性在当前对象实例中是否存在。
alert(person.hasOwnProperty("name"));//true
alert(person.hasOwnProperty("age")); //true
alert(person.hasOwnProperty("birth")); //false
3.isPrototypeOf(Object)方法
isPrototype()方法接收一个对象,用来判断当前对象是否在传入的参数对象的原型链上,说起来有点抽象,我们来看看代码。
function MyObject(){
}
var obj = new MyObject();
alert(Object.prototype.isPrototypeOf(obj));//true
我们知道MyObject是继承自Object对象的,而在JS中,继承是通过prototype来实现的,所以Object的prototype必定在MyObject对象实例的原型链上。
4.propertyIsEnumerable(prototypeName)方法
prototypeIsEnumerable用来判断给定的属性是否可以被for..in语句给枚举出来。obj的属性还有很多,比如constructor,比如hasOwnPrototype等等,但是它们没有被输出,说明这些属性不能被for…in给枚举出来,可以通过propertyIsEnumerable方法来得到。
var person = {};
person.name = "Tom";
person.age = 20;
person.say = function(){
alert("Hello!!!");
}
alert(person.propertyIsEnumerable("name")) //true
alert(person.propertyIsEnumerable("age")) //true
alert(person.propertyIsEnumerable("constructor")) //false
5.toLocalString()方法
toLocalString方法返回对象的字符串表示,和代码的执行环境有关。
var obj = {};
alert(obj.toLocaleString());//[object Object]
var date = new Date();
alert(date.toLocaleString());// 2016/4/27 上午11:47:35
6.toString()方法
toString用来返回对象的字符串表示。
var obj = {};
alert(obj.toString());//[object Object]
var date = new Date();
alert(date.toString());// Wed Apr 27 2016 11:50:57 GMT+0800
7.valueOf()方法
返回对象的原始值,可能是字符串、数值或布尔类型。
三、Object的简单应用
1.模拟Java中的Map
function Map(){
var obj = {};
//put方法
this.put = function(key,value){
//把键值对绑定的obj对象上
obj[key] = value;
}
//size(): 获取map个数
this.size = function(){
var count = 0;
for(var attr in obj){
count++;
}
return count;
}
//get():根据key获得value
this.get = function(key){
if(obj[key] || obj[key] === 0 || obj[key] ===false){
return obj[key];
}
else{
return null;
}
}
//remove():移除元素
this.remove = function(key){
if(obj[key] || obj[key] === 0 || obj[key] ===false){
delete obj[key];
}
}
//eacbhMap遍历Map的方法
this.eachMap = function(fn){
for(var attr in obj){
fn(attr,obj[attr]);
}
}
}
//模拟Java中的Map
var map = new Map();
map.put("01","abc");
map.put("02",0);
map.put("03",true);
map.put("04",new Date());
alert(map.size()); //4
alert(map.get("02")); //0
map.eachMap(function(key,value){
alert(key + " = " + value);
});
JavaScript基础学习(四)—Object的更多相关文章
- JavaScript 基础 学习 (四)
JavaScript 基础 学习 (四) 解绑事件 dom级 事件解绑 元素.on事件类型 = null 因为赋值的关系,所以给事件赋值为 null 的时候 事件触发的时候,就没有事件处理 ...
- JavaScript 基础学习1-day14
JavaScript 基础学习1 知识预览JavaScript概述二 JavaScript的基础三 JavaScript的对象BOM对象DOM对象实例练习js扩展 JavaScript概述 JavaS ...
- JavaScript 基础 学习(三)
JavaScript 基础 学习(三) 事件三要素 1.事件源: 绑定在谁身上的事件(和谁约定好) 2.事件类型: 绑定一个什么事件 3.事件处理函数: 当行为发生的时候,要执行哪一个函数 ...
- 48.javascript基础学习
javascript基础学习: http://www.w3school.com.cn/jsref/index.asp jS的引入方式: 1.行间事件:为某一个具体的元素标签赋予js内容,oncli ...
- JavaScript 基础学习(二)js 和 html 的结合方式
第一种 使用一个标签 <script type="text/javascript"> js代码; </script> 第二种 使用 script 标签,引入 ...
- Python基础学习四
Python基础学习四 1.内置函数 help()函数:用于查看内置函数的用途. help(abs) isinstance()函数:用于判断变量类型. isinstance(x,(int,float) ...
- JavaScript 基础 学习 (二)
JavaScript 基础 学习 节点属性 每一个节点都有自己的特点 这个节点属性就记录着属于自己节点的特点 1. nodeType(以一个数字来表示这个节点类型) 语法:节点.nodeT ...
- JavaScript 基础 学习 (一)
JavaScript 基础 学习 获取页面中的元素的方法 作用:通过各种方式获取页面中的元素 比如:id,类名,标签名,选择器 的方式来获取元素 伪数组: 长的和数组差不多,也是按照索引排 ...
- 几张非常有意义的JavaScript基础学习思维图
分享几张对于学习JavaScript基础知识非常有意义的图,无论你的JavaScript级别如何,“温故而知新”完全可以从这些图中得到. 推荐理由:归类非常好,非常全面 JavaScript 数组 J ...
随机推荐
- 分布式配置管理--百度disconf搭建过程和详细使用
先说官方文档:http://disconf.readthedocs.io/zh_CN/latest/index.html 不管是否要根据官方文档来搭建disconf,都应该看一下这一份文档.精炼清晰地 ...
- Python 3 读写文件的简单方法!
Python 3 读写文件的简单方法! a = open('test.txt','w') 这行代码创建了一个名为test的文本文档,模式是写入(模式分为三种,w代表写入,r代表阅读,a代表在尾行添加) ...
- Spring MVC + Security 4 初体验(Java配置版)
spring Version = 4.3.6.RELEASE springSecurityVersion = 4.2.1.RELEASE Gradle 3.0 + Eclipse Neno(4.6) ...
- 前端基本知识(四):JS的异步模式:1、回调函数;2、事件监听;3、观察者模式;4、promise对象
JavaScript语言将任务的执行模式可以分成两种:同步(Synchronous)和异步(Asychronous). “同步模式”就是一个任务完成之后,后边跟着一个任务接着执行:程序的执行顺序和排列 ...
- Visual Studio 20周年软件趋势随想
从2002年开始,.net让开发人员能快速构建和部署应用程序,便捷的开发windows和web服务器应用,同时著名的hacker Miguel de Icaza ,Miguel 为了GNOME项目启动 ...
- hibernate jar包介绍
Hibernate3.jar 这个是hibernate最主要的jar包 ant-1.63.jar Ant 的核心包,在构建Hibernate 时会用到 antlr-2. ...
- JavaScript 图片轮播入门
轮播要求:一个在页面居中的矩形框,图片依次从矩形框中经过 当图片完整占满矩形框时 停留一小段时间再向左边移动经过矩形框的图片自动跑到右边最后一个图的后面.核心原理:在一个for循环中利用offsetl ...
- MacOS无法登录App Store修复
MacOS无法登录App Store修复 2017-03-10 21:13:39 by:SemiconductorKING 先上图: 惨红色的提示信息,把你拒之App Store门外,但是对之放弃. ...
- Contains Duplicate leetcode
Given an array of integers, find if the array contains any duplicates. Your function should return t ...
- 使用Task的一些知识优化了一下同事的多线程协作取消的一串代码
最近在看一个同事的代码,代码的本意是在main方法中开启10个线程,用这10个线程来处理一批业务逻辑,在某一时刻当你命令console退出的时候,这个 时候不是立即让console退出,而是需要等待1 ...