【追寻javascript高手之路03】javascript对象大乱斗
前言
昨天我们学习了下javascript中函数的参数与作用域的东东,现在回过头来看,其实都是与函数相关的,所以javascript中的函数仍然是王道,我们今天大概会发二篇或者三篇博客一起来巩固我们的javascript吧!
PS:各位,阿里失败啦,这个事情不必关心啦......我下周再找工作了
object 类型
我们有两种方式可定义一个对象:
var object = {};
var object = new Object();
PS:根据对象字面量创建的对象不会调用Object构造函数
javascript中的对象类似于我们的hashtable,是一种键值对的形式,他可以以不同维度方式展示,某些时候甚至可以模拟我们的数据库结构!
对象在内存的存储方式是将具体的存在堆里面,而在栈里面保存一个引用,所以我们经常遇到两个有意思的东东,
一个是引用赋值,后者变化而影响前者,一者就是深度克隆了,我们在此看看这两个东东:
var a = { a: 6 };
alert(a.a);//
var b = a;
b.a = 66;
alert(a.a);//
这个题,我们昨天就见过了,这里再提出来说下,于是我们来看看深度克隆呢:
PS:这里先科普一下克隆吧,可能有些朋友还不知道什么意思呢
浅度克隆:基本类型为值传递,对象仍为引用传递。
深度克隆:所有元素或属性均完全克隆,并于原引用类型完全独立,即,在后面修改对象的属性的时候,原对象不会被修改。
这里还会用到下面这个东东:
hasOwnProperty:
是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
function cloneObj(obj) {
var o = obj.constructor == Array ? [] : {}; //首先处理变量,看看是数组还是对象啦
for (var k in obj) {
//我们知道for in 会将原型的东西也给遍历出来,所以我们这里需要做一个判断
if (obj.hasOwnProperty(k)) {
//递归方式处理
o[k] = typeof obj[k] === 'objext' ? cloneObj(obj[k]) : obj[k];
}
}
return o;
} var a = { a: 'aaa', b: 'bbb', c: { d: 'ddd', e: [1, 2, 4]} };
var b = cloneObj(a);
var s = '';
好了,我们对对象的学习暂时到这里,下面来看看数组吧。
Array类型
无论什么语言,数组与字符串的操作都是十分常见的,我们这里就来理一理我们javascript中的数组。
定义数组
定义数组的方式多种多样,我一般会用到其中两种,确切的说,我会用其中一种:
var arr = [];
var arr = new Array();
var arr = [1, 2, 3];
var arr = new Array(1, 2, 3);
数组字面量是我们所亲睐的做法。
javascript中数组的长度是不定的,数组各个项目的类型也是可以变的,所以用起来非常灵活。
检测数组
我们经常需要判断一个对象是不是数组(数组也是对象,其Array实一个构造函数哦),于是我们会用到以下方法:
var a = arr.constructor == Array;//true
var b = arr instanceof Array; //true
var c = Array.isArray(arr); //true,ECMAScript5新增
本来instanceof足够满足条件了,但是有这么一个情况就是我们页面中存在几个框架,每个框架都有其window全局环境,所以就可能出现2个Array构造函数。
数组与字符串
数组与字符串经常做转换,字符串转换为数组使用split,数组转换为字符串却有多种方案:
var b = [1, 'fdsffd', '速度多少'];
var a = [ {a: 'aaa'}, {b: 'bbb'}, {c: { d: 'ddd', e: [1, 2, 4]} }];
var str1 = a.toString(); //"[object Object],[object Object],[object Object]"
var str2 = b.toString(); //"1,fdsffd,速度多少"
所以我们要将复杂的转换为字符串还是要费点功夫,但是有个叫JSON的家伙已经帮我们干了这些事情了。。。
若是各位对","分割不过瘾,可以使用join方法选择自己喜欢的分割方式。
增加项目
增加数组项目也有多种方法,但是我们一般使用push的方式,这里可能涉及到一点点删除的功能了。
针对栈的功能,js提供了push与pop两个东西,一个是加入,一个是弹出最上面的并且删除,其实都是数组尾部操作比较容易理解:
var arr = [1, 'fdsffd', '速度多少'];
arr.push('新增01', '新增02'); //可以操作多个哦
var dd = arr.pop();
var s = '';
另外一个东西就是模拟队列的操作了,模拟队列的话删除是会在数组的头部做操作,他隐藏了整个数组的移动:
var arr = [1, 'fdsffd', '速度多少'];
arr.push('新增01', '新增02'); //可以操作多个哦
var dd = arr.shift();
其中这个shift我们需要抽出来单独处理一番。
shift用于取得数组的第一项,并且将之移除,整个数组下标会变化,长度减1
与之对应的是unshift,会在队列最前面增加数组,而不必关心下标的操作
PS:我在想javascript有没有封装一个在数组中间删除项目的方法。。。好像没有找到
数组排序
数组排序是我们经常遇到的东西,一般使用reverse与sort即可。
reverse比较简单便是翻转数组,sort方法比较常用,其中可以用于复杂数组的排序:
var arr = [{ id: 1, name: '叶小钗' }, { id: 2, name: '素还真' }, { id: 3, name: '一页书'}];
arr.sort(function (v1, v2) {
if (v1.id < v2.id) {
return 1;
} else if (v1.id > v2.id) {
return -1;
} else {
return 0;
}
});
基于当前数组创建新数组
concat可以根据当前数组创建新的数组,说白了就是将两个数组变成一个:
var arr = [{ id: 1, name: '叶小钗' }, { id: 2, name: '素还真' }, { id: 3, name: '一页书'}];
var newArr = arr.concat('11', [3, 4]);
另外一个方法为slice,他可以根据当前数组项目,由里面抽取几项组成新的数组:
var arr = [{ id: 1, name: '叶小钗' }, { id: 2, name: '素还真' }, { id: 3, name: '一页书'}];
var newArr = arr.concat('11', [3, 4]);
var arr2 = newArr.slice(1, 4);//1 到 4直接位置的数组一共三项
最强的方法splice
刚刚还在说没有找到删除数组中间项目的方法呢,现在就冒了一个增加/删除 数组中间项目的方法,这个需要好好研究一番。
splice有三种用法:
删除:
可以删除任意数量项目,需要两个参数:删除的位置;删除的项目
splice(1, 2)会删除第2,3 项,而且数组下标长度会自己变化,真是好东西啊! 插入:
可以向指定位置插入任意项目的项,三个参数:初始位置、0(删除的项目)、插入的项目,这个有点重载的感觉
splice(2, 0, '叶小钗', '素还真');将在第三项后面插入两项 替换:
按道理说,替换不该用到这个东西,但是我们还是看看吧。
他的功能事实上市先删除在插入,三个参数:起始位置、删除项目、插入项目
splice(2, 1, 'red');将删除第二项并插入red
ECMAScript 5新增
ECMAScript 5新增了两个取得位置的方法:indexOf与lastIndexOf,与字符串使用方法类似:
indexOf:由头开始找寻
lastIndexOf:由尾部开始找寻
还增加了迭代方法与归并方法,本来数组的方法我就用得不多,这些便暂时略去了,到要用到时候再查下吧。
Date类型
时间操作函数,也是我们javascript经常会用到的对象,要创建一个日期对象很简单:
var d = new Date(); //Date {Sat Jun 29 2013 11:30:36 GMT+0800}
这里来一个有意思的初始化方式:
var d = new Date(2013, 5, 29, 11, 32, 10);
//注意此处第二个参数是月份,这里的5代表六!!!这个在有些地方容易引起错误
关于日期的用法,我这里不多说,便上一个例子吧:
网页中实现一个计算当年还剩多少时间的倒数计时程序,要求网页上实时动态显示“××年还剩××天××时××分××秒”
function counter() {
var date = new Date();
var year = date.getFullYear();
var date2 = new Date(year, 12, 31, 23, 59, 59);
var time = (date2 - date) / 1000;
var day = Math.floor(time / (24 * 60 * 60))
var hour = Math.floor(time % (24 * 60 * 60) / (60 * 60))
var minute = Math.floor(time % (24 * 60 * 60) % (60 * 60) / 60);
var second = Math.floor(time % (24 * 60 * 60) % (60 * 60) % 60);
var str = year + "年还剩" + day + "天" + hour + "时" + minute + "分" + second + "秒";
document.getElementById("input").value = str;
}
window.setInterval("counter()", 1000);
PS:这个例子是抄来的,各位看他有什么问题没有呢???提示:月份
RegExp类型
对于正则表达式的使用其实我一直不太在行,每次都是学了就忘了再学在忘,纠其原因还是因为用得太少啦。
创建正则
我们有两种方法创建一个正则表达式:
var pattern = /....../;
var pattern = new RegExp('......');
//推荐使用第一种
RegExp实例属性
每个正则表达式实例皆具有以下属性:
global: 表示是否设置了g标志
var pattern = /at/g;//表示匹配所以at ignoreCase:表示是否启用了i标志
var pattern = /at/i;不区分大小写 lastIndex:整数,表示开始搜索下一个匹配字符的位置,0开始 multiline:表示是否启用多行匹配 source:正则表达式的字符串表示,按照字面形式而不是传入构造函数中的字符串模式返回
关于正则表达式,我后面点单独写一篇博客算了,这里暂时到这里了
正则的学习需要多花功夫才行,这块太水了,这里搞完了又忘了
结语
上午的学习暂时到这里,我出去吃个饭,下午我们继续学习!
【追寻javascript高手之路03】javascript对象大乱斗的更多相关文章
- 【追寻javascript高手之路05】理解事件流
前言 新的一天又开始了,我们对今天对未来抱有很大期待,所以开始我们今天的学习吧,在此之前来点题外话,还是爱好问题. 周三的面试虽然失败,但是也是很有启迪的,比如之前我就从来没有想过爱好问题,我发现我的 ...
- 【追寻javascript高手之路02】变量、作用域知多少?
前言 本来想把这个与上篇博客写到一起的,但是考虑到是两个知识点还是分开算了,于是我们继续今天的学习吧. 基本类型与引用类型 ECMAScript的的变量有两种类型: 基本类型(值类型):简单数据段 引 ...
- 【追寻javascript高手之路01】javascript参数知多少?
前言 我最近在思考一个问题,我本身平时还是积累了不少东西,面试时候问的东西基本逃不出写的博客(当然,高级阶段的就不行了),但是真的被问到时我却不一定答得上来. 知道且能回答,回答的效果都不是很好... ...
- 【追寻javascript高手之路04】理解prototype
前言 中午时候我去药店称了下体重,好家伙!我减肥成功了,足足比上个月瘦了10斤!于是想减肥就去郑州吧... 然后回来迷迷糊糊睡了一会,居然想起了周三的面试,有点小遗憾有点小触动. 这次回成都后,还没有 ...
- [js高手之路]使用原型对象(prototype)需要注意的地方
我们先来一个简单的构造函数+原型对象的小程序 function CreateObj( uName, uAge ) { this.userName = uName; this.userAge = uAg ...
- [js高手之路] javascript面向对象写法与应用
一.什么是对象? 对象是n个属性和方法组成的集合,如js内置的document, Date, Regexp, Math等等 document就是有很多的属性和方法, 如:getElementById, ...
- javaScript系列 [03]-javaScript原型对象
[03]-javaScript原型对象 引用: javaScript是一门基于原型的语言,它允许对象通过原型链引用另一个对象来构建对象中的复杂性,JavaScript使用原型链这种机制来实现动态代理. ...
- Javascript进阶之路-论对象的重要性
要了解JavaScript对象,我们可以从对象创建.属性操作.对象方法这几个方面入手.概括起来,包括以下几模块: 1.创建对象 1.1 对象直接量 1.2 通过new创建对 ...
- [js高手之路]原型对象(prototype)与原型链相关属性与方法详解
一,instanceof: instanceof检测左侧的__proto__原型链上,是否存在右侧的prototype原型. 我在之前的两篇文章 [js高手之路]构造函数的基本特性与优缺点 [js高手 ...
随机推荐
- QQ左侧滑动显示
对于新版的QQ界面,左侧增加了一个滑动效果,相信小伙伴们早已按耐不住激动的心情,这种效果是如何实现的呢?本篇我们就一起来探讨一二.既然是滑动效果这里就要使用到HorizontalScrollView类 ...
- jsp实现简单的分页
效果如下:<%-- Document : page Created on : 2014-11-18, 8:55:02 Author : HJZ --%> <%@page conten ...
- AngularJS in Action读书笔记5(实战篇)——在directive中引入D3饼状图显示
前言: "宁肯像种子一样等待 也不愿像疲惫的陀螺 旋转得那样勉强" 这是前几天在查资料无意间看到的一位园友的签名,看完后又读了两遍,觉得很有味道.后来一寻根究底才知这是出资大诗 ...
- HTML Inspector – 帮助你编写高质量的 HTML 代码
HTML Inspector 是一款代码质量检测工具,帮助你编写更优秀的 HTML 代码.HTML Inspector 使用 JavaScript 编写,运行在浏览器中,是最好的 HTML 代码检测工 ...
- 16个时髦的扁平化设计的 HTML5 & CSS3 网站模板
创建网站最好办法之一是使用现成的网站模板或使用开源 CMS 应用程序.所以,今天这篇文章给大家带来的是16款基于 HTML5 & CSS3 的精美的扁平风格网站模板,大家可以借助这些优秀的网站 ...
- Head插件——学习Elasticsearch的锋刃利器!
在学习Elasticsearch的过程中,必不可少需要通过一些工具查看es的运行状态以及数据.如果都是通过rest请求,未免太过麻烦,而且也不够人性化. 此时,head可以完美的帮助你快速学习和使用e ...
- Elasticsearch——Date Math在索引中的用法详解
在elasticsearch中,有时会想要通过索引日期来筛选查询的数据,此时就需要用到日期数学表达式. 更多内容参考Elasticsearch翻译汇总 基于日期数学表达式的索引 模式如下: <s ...
- ROS 新手常见问题汇总
版权声明:本文为博主原创文章,转载请标明出处: http://www.cnblogs.com/liu-fa/p/5772469.html 该博文致力于汇总ROS常见问题及解答,让更多的人少走弯路,避免 ...
- Python生成二维码脚本
简单的记录下二维码生成和解析的Python代码 依赖下面三个包: PIL(图像处理包,安装:pip install PIL) qrcode(二维码生成包,安装:pip install qrcode) ...
- web前端学习笔记---实现雪花飘落的效果
看了javascript网页特效实例大全中的图片飘下的效果实例,觉得值得动手学习下. 就把图片改成雪花图,完成一个雪花飘下的效果. 并且,其中有些内容比较陈旧了,那么就学者改掉吧. 包括: 1.对le ...