详解JavaScript的内置对象


Posted in Javascript onDecember 07, 2016

什么是对象

JavaScript 中的所有事物都是对象,如:字符串、数值、数组、函数等,每个对象带有属性和方法。

对象的属性:反映该对象某些特定的性质的,如:字符串的长度、图像的长宽等;

对象的方法:能够在对象上执行的动作。例如,表单的“提交”(Submit),时间的“获取”(getYear)等;

JavaScript 提供多个内建对象,比如 String、Date、Array 等等,使用对象前先定义,如下使用数组对象:

var objectName =new Array();//使用new关键字定义对象

或者

 var objectName =[];

访问对象属性的语法:

objectName.propertyName

如使用 Array 对象的 length 属性来获得数组的长度:

var myarray=new Array(6);//定义数组对象
var myl=myarray.length;//访问数组长度length属性

以上代码执行后,myl的值将是:6

访问对象的方法:

objectName.methodName()

如使用string 对象的 toUpperCase() 方法来将文本转换为大写:

var mystr="Hello world!";//创建一个字符串
var request=mystr.toUpperCase(); //使用字符串对象方法

以上代码执行后,request的值是:HELLO WORLD!

Date 日期对象

日期对象可以储存任意一个日期,并且可以精确到毫秒数(1/1000 秒)。

定义一个时间对象 :

var Udate=new Date();

注意:使用关键字new,Date()的首字母必须大写。

使 Udate 成为日期对象,并且已有初始值:当前时间(当前电脑系统时间)。

如果要自定义初始值,可以用以下方法:

var d = new Date(2012, 10, 1); //2012年10月1日
var d = new Date('Oct 1, 2012'); //2012年10月1日

我们最好使用下面介绍的“方法”来严格定义时间。

访问方法语法:“<日期对象>.<方法>”

Date对象中处理时间和日期的常用方法:

详解JavaScript的内置对象

返回/设置年份方法

get/setFullYear() 返回/设置年份,用四位数表示。

var mydate=new Date();//当前时间2014年3月6日
document.write(mydate+"<br>");//输出当前时间
document.write(mydate.getFullYear()+"<br>");//输出当前年份
mydate.setFullYear(81); //设置年份
document.write(mydate+"<br>"); //输出年份被设定为 0081年。

注意:不同浏览器,mydate.setFullYear(81)结果不同,年份被设定为 0081或81两种情况。

结果:

Thu Mar 06 2014 10:57:47 GMT+0800
2014
Thu Mar 06 0081 10:57:47 GMT+0800

注意:

  • 结果格式依次为:星期、月、日、年、时、分、秒、时区。(火狐浏览器)
  • 不同浏览器,时间格式有差异。

返回星期方法

getDay() 返回星期,返回的是0-6的数字,0 表示星期天。如果要返回相对应“星期”,通过数组完成,代码如下:

<script type="text/javascript">
 var mydate=new Date();//定义日期对象
 var weekday=["星期日","星期一","星期二","星期三","星期四","星期五","星期六"];
//定义数组对象,给每个数组项赋值
 var mynum=mydate.getDay();//返回值存储在变量mynum中
 document.write(mydate.getDay());//输出getDay()获取值
 document.write("今天是:"+ weekday[mynum]);//输出星期几
</script>

注意:以上代码是在2016年3月2日,星期三运行。

结果:

3
今天是:星期三

返回/设置时间方法

get/setTime() 返回/设置时间,单位毫秒数,计算从 1970 年 1 月 1 日零时到日期对象所指的日期的毫秒数。

如果将目前日期对象的时间推迟1小时,代码如下:

<script type="text/javascript">
 var mydate=new Date();
 document.write("当前时间:"+mydate+"<br>");
 mydate.setTime(mydate.getTime() + 60 * 60 * 1000);
 document.write("推迟一小时时间:" + mydate);
</script>

结果:

当前时间:Thu Mar 6 11:46:27 UTC+0800 2014

推迟一小时时间:Thu Mar 6 12:46:27 UTC+0800 2014

注意:

  • 一小时 60 分,一分 60 秒,一秒 1000 毫秒
  • 时间推迟 1 小时,就是: “x.setTime(x.getTime() + 60 60 1000);”

String 字符串对象

定义字符串的方法就是直接赋值。比如:

var mystr = "I love JavaScript!"

定义mystr字符串后,我们就可以访问它的属性和方法。

访问字符串对象的属性length:

stringObject.length; 返回该字符串的长度。

var mystr="Hello World!";
var myl=mystr.length;

以上代码执行后,myl 的值将是:12

访问字符串对象的方法:

使用 String 对象的 toUpperCase() 方法来将字符串小写字母转换为大写:

var mystr="Hello world!";
var mynum=mystr.toUpperCase();

以上代码执行后,mynum 的值是:HELLO WORLD!

返回指定位置的字符

charAt() 方法可返回指定位置的字符。返回的字符是长度为 1 的字符串。

语法:

stringObject.charAt(index)

参数说明:

详解JavaScript的内置对象

注意:

1.字符串中第一个字符的下标是 0。最后一个字符的下标为字符串长度减一(string.length-1)。

2.如果参数 index 不在 0 与 string.length-1 之间,该方法将返回一个空字符串。

如:在字符串 "I love JavaScript!" 中,返回位置2的字符:

<script type="text/javascript">
 var mystr="I love JavaScript!"
 document.write(mystr.charAt(2));
</script>

注意:一个空格也算一个字符。

以上代码的运行结果:

l

返回指定的字符串首次出现的位置

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。

语法

stringObject.indexOf(substring, startpos)

参数说明:

详解JavaScript的内置对象

说明:

1.该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 substring。

2.可选参数,从stringObject的startpos位置开始查找substring,如果没有此参数将从stringObject的开始位置查找。

3.如果找到一个 substring,则返回 substring 的第一次出现的位置。stringObject 中的字符位置是从 0 开始的。

注意:

1.indexOf() 方法区分大小写。

2.如果要检索的字符串值没有出现,则该方法返回 -1。

例如: 对 "I love JavaScript!" 字符串内进行不同的检索:

<script type="text/javascript">
 var str="I love JavaScript!"
 document.write(str.indexOf("I") + "<br />");
 document.write(str.indexOf("v") + "<br />");
 document.write(str.indexOf("v",8));
</script>

以上代码的输出:

0
4
9

字符串分割split()

知识讲解:

split() 方法将字符串分割为字符串数组,并返回此数组。

语法:

stringObject.split(separator,limit)

参数说明:

详解JavaScript的内置对象

注意:如果把空字符串 ("") 用作 separator,那么 stringObject 中的每个字符之间都会被分割。

我们将按照不同的方式来分割字符串:

使用指定符号分割字符串,代码如下:

var mystr = "www.baidu.com";
document.write(mystr.split(".")+"<br>");
document.write(mystr.split(".", 2)+"<br>");

运行结果:

www,baidu,com
www,baidu

将字符串分割为字符,代码如下:

document.write(mystr.split("")+"<br>");
document.write(mystr.split("", 5));

运行结果:

w,w,w,.,b,a,i,d,u,.,c,o,m
w,w,w,.,b

提取字符串substring()

substring() 方法用于提取字符串中介于两个指定下标之间的字符。

语法:

stringObject.substring(starPos,stopPos)

参数说明:

详解JavaScript的内置对象

注意:

返回的内容是从 start开始(包含start位置的字符)到 stop-1 处的所有字符,其长度为 stop 减start。

如果参数 start 与 stop 相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。

如果 start 比 stop 大,那么该方法在提取子串之前会先交换这两个参数。

使用 substring() 从字符串中提取字符串,代码如下:

<script type="text/javascript">
 var mystr="I love JavaScript";
 document.write(mystr.substring(7));
 document.write(mystr.substring(2,6));
</script>

运行结果:

JavaScript
love

提取指定数目的字符substr()

substr() 方法从字符串中提取从 startPos位置开始的指定数目的字符串。

语法:

stringObject.substr(startPos,length)

参数说明:

详解JavaScript的内置对象

注意:如果参数startPos是负数,从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。

如果startPos为负数且绝对值大于字符串长度,startPos为0。

使用 substr() 从字符串中提取一些字符,代码如下:

<script type="text/javascript">
 var mystr="I love JavaScript!";
 document.write(mystr.substr(7));
 document.write(mystr.substr(2,4));
</script>

运行结果:

JavaScript!
love

Math对象

Math对象,提供对数据的数学计算。

使用 Math 的属性和方法,代码如下:

<script type="text/javascript">
 var mypi=Math.PI; 
 var myabs=Math.abs(-15);
 document.write(mypi);
 document.write(myabs);
</script>

运行结果:

3.141592653589793
15

注意:Math 对象是一个固有的对象,无需创建它,直接把 Math 作为对象使用就可以调用其所有属性和方法。这是它与Date,String对象的区别。

Math 对象属性

详解JavaScript的内置对象

Math 对象方法

详解JavaScript的内置对象

向上取整ceil()

ceil() 方法可对一个数进行向上取整。

语法:

Math.ceil(x)

详解JavaScript的内置对象

注意:它返回的是大于或等于x,并且与x最接近的整数。

我们将把 ceil() 方法运用到不同的数字上,代码如下:

<script type="text/javascript">
 document.write(Math.ceil(0.8) + "<br />")
 document.write(Math.ceil(6.3) + "<br />")
 document.write(Math.ceil(5) + "<br />")
 document.write(Math.ceil(3.5) + "<br />")
 document.write(Math.ceil(-5.1) + "<br />")
 document.write(Math.ceil(-5.9))
</script>

运行结果:

1
7
5
4
-5
-5

向下取整floor()

floor() 方法可对一个数进行向下取整。

语法:

Math.floor(x)

参数说明:

详解JavaScript的内置对象

注意:返回的是小于或等于x,并且与 x 最接近的整数。

我们将在不同的数字上使用 floor() 方法,代码如下:

<script type="text/javascript">
 document.write(Math.floor(0.8)+ "<br>")
 document.write(Math.floor(6.3)+ "<br>")
 document.write(Math.floor(5)+ "<br>")
 document.write(Math.floor(3.5)+ "<br>")
 document.write(Math.floor(-5.1)+ "<br>")
 document.write(Math.floor(-5.9))
</script>

运行结果:

0
6
5
3
-6
-6

四舍五入round()

round() 方法可把一个数字四舍五入为最接近的整数。

语法:

Math.round(x)

参数说明:

详解JavaScript的内置对象

注意:

返回与 x 最接近的整数。

对于 0.5,该方法将进行上舍入。(5.5 将舍入为 6)

如果 x 与两侧整数同等接近,则结果接近 +∞方向的数字值 。(如 -5.5 将舍入为 -5; -5.52 将舍入为 -6),如下图:

详解JavaScript的内置对象

把不同的数舍入为最接近的整数,代码如下:

<script type="text/javascript">
 document.write(Math.round(1.6)+ "<br>");
 document.write(Math.round(2.5)+ "<br>");
 document.write(Math.round(0.49)+ "<br>");
 document.write(Math.round(-6.4)+ "<br>");
 document.write(Math.round(-6.6));
</script>

运行结果:

2
3
0
-6
-7

随机数 random()

random() 方法可返回介于 0 ~ 1(大于或等于 0 但小于 1 )之间的一个随机数。

语法:

Math.random();

注意:返回一个大于或等于 0 但小于 1 的符号为正的数字值。

我们取得介于 0 到 1 之间的一个随机数,代码如下:

<script type="text/javascript">
 document.write(Math.random());
</script>

运行结果:

0.190305486195328

注意:因为是随机数,所以每次运行结果不一样,但是0 ~ 1的数值。

获得0 ~ 10之间的随机数,代码如下:

<script type="text/javascript">
 document.write((Math.random())*10);
</script>

运行结果:

8.72153625893887

Array 数组对象

数组对象是一个对象的集合,里边的对象可以是不同类型的。数组的每一个成员对象都有一个“下标”,用来表示它在数组中的位置,是从零开始的

数组定义的方法:

1.定义了一个空数组:

var  数组名= new Array();

2.定义时指定有n个空元素的数组:

var 数组名 =new Array(n);

3.定义数组的时候,直接初始化数据:

var  数组名 = [<元素1>, <元素2>, <元素3>...];

我们定义myArray数组,并赋值,代码如下:

var myArray = [2, 8, 6];

说明:定义了一个数组 myArray,里边的元素是:myArray[0] = 2; myArray[1] = 8; myArray[2] = 6。

数组元素使用:

数组名[下标] = 值;

注意: 数组的下标用方括号括起来,从0开始。

数组属性:

length 用法:<数组对象>.length;返回:数组的长度,即数组里有多少个元素。它等于数组里最后一个元素的下标加一。

数组方法:

详解JavaScript的内置对象

数组连接concat()

concat() 方法用于连接两个或多个数组。此方法返回一个新数组,不改变原来的数组。

语法

arrayObject.concat(array1,array2,...,arrayN)

参数说明:

详解JavaScript的内置对象

注意: 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。

我们创建一个数组,将把 concat() 中的参数连接到数组 myarr 中,代码如下:

<script type="text/javascript">
 var mya = new Array(3);
 mya[0] = "1";
 mya[1] = "2";
 mya[2] = "3";
 document.write(mya.concat(4,5)+"<br>");
 document.write(mya); 
</script>

运行结果:

1,2,3,4,5
1,2,3

我们创建了三个数组,然后使用 concat() 把它们连接起来,代码如下:

<script type="text/javascript">
 var mya1= new Array("hello!")
 var mya2= new Array("I","love");
 var mya3= new Array("JavaScript","!");
 var mya4=mya1.concat(mya2,mya3);
 document.write(mya4);
</script>

运行结果:

hello!,I,love,JavaScript,!

指定分隔符连接数组元素join()

join()方法用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的。

语法:

arrayObject.join(分隔符)

参数说明:

详解JavaScript的内置对象

注意:返回一个字符串,该字符串把数组中的各个元素串起来,用<分隔符>置于元素与元素之间。这个方法不影响数组原本的内容。 我们使用join()方法,将数组的所有元素放入一个字符串中,代码如下:

<script type="text/javascript">
 var myarr = new Array(3);
 myarr[0] = "I";
 myarr[1] = "love";
 myarr[2] = "JavaScript";
 document.write(myarr.join());
</script>

运行结果:

I,love,JavaScript

我们将使用分隔符来分隔数组中的元素,代码如下:

<sript type="text/javascript">
 var myarr = new Array(3)
 myarr[0] = "I";
 myarr[1] = "love";
 myarr[2] = "JavaScript";
 document.write(myarr.join("."));
</script>

运行结果:

I.love.JavaScript

颠倒数组元素顺序reverse()

reverse() 方法用于颠倒数组中元素的顺序。

语法:

arrayObject.reverse()

注意:该方法会改变原来的数组,而不会创建新的数组。

定义数组myarr并赋值,然后颠倒其元素的顺序:

<script type="text/javascript">
 var myarr = new Array(3)
 myarr[0] = "1"
 myarr[1] = "2"
 myarr[2] = "3"
 document.write(myarr + "<br />")
 document.write(myarr.reverse())
</script>

运行结果:

1,2,3
3,2,1

选定元素slice()

slice() 方法可从已有的数组中返回选定的元素。

语法

arrayObject.slice(start,end)

参数说明:

详解JavaScript的内置对象

1.返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

该方法并不会修改数组,而是返回一个子数组。

注意:

可使用负值从数组的尾部选取元素。

2.如果 end 未被规定,那么 slice() 方法会选取从 start 到数组结尾的所有元素。

String.slice()与 Array.slice() 相似。

我们将创建一个新数组,然后从其中选取的元素,代码如下:

<script type="text/javascript">
 var myarr = new Array(1,2,3,4,5,6);
 document.write(myarr + "<br>");
 document.write(myarr.slice(2,4) + "<br>");
 document.write(myarr);
</script>

运行结果:

1,2,3,4,5,6
3,4
1,2,3,4,5,6

数组排序sort()

sort()方法使数组中的元素按照一定的顺序排列。

语法:

arrayObject.sort(方法函数)

参数说明:

详解JavaScript的内置对象

1.如果不指定<方法函数>,则按unicode码顺序排列。

2.如果指定<方法函数>,则按<方法函数>所指定的排序方法排序。

myArray.sort(sortMethod);

注意: 该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若返回值<=-1,则表示 A 在排序后的序列中出现在 B 之前。

若返回值>-1 && <1,则表示 A 和 B 具有相同的排序顺序。 若返回值>=1,则表示 A 在排序后的序列中出现在 B 之后。

1.使用sort()将数组进行排序,代码如下:

<script type="text/javascript">
 var myarr1 = new Array("Hello","John","love","JavaScript"); 
 var myarr2 = new Array("80","16","50","6","100","1");
 document.write(myarr1.sort()+"<br>");
 document.write(myarr2.sort());
</script>

运行结果:

Hello,JavaScript,John,love
1,100,16,50,6,80

注意:上面的代码没有按照数值的大小对数字进行排序。

2.如要实现这一点,就必须使用一个排序函数,代码如下:

<script type="text/javascript">
 function sortNum(a,b) {
 return a - b;
 //升序,如降序,把“a - b”该成“b - a”
}
 var myarr = new Array("80","16","50","6","100","1");
 document.write(myarr + "<br>");
 document.write(myarr.sort(sortNum));
</script>

运行结果:

80,16,50,6,100,1
1,6,16,50,80,100

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
使用IE6看老赵的博客 jQuery初探
Jan 17 Javascript
jQuery ctrl+Enter shift+Enter实现代码
Feb 07 Javascript
javascript 函数调用的对象和方法
Jul 01 Javascript
解决Extjs上传图片无法预览的解决方法
Mar 22 Javascript
easyui Droppable组件实现放置特效
Aug 19 Javascript
Bootstrap 网站实例之单页营销网站
Oct 20 Javascript
JavaScript浏览器对象模型BOM(BrowserObjectModel)实例详解
Nov 29 Javascript
EasyUI的DataGrid每行数据添加操作按钮的实现代码
Aug 22 Javascript
JavaScript中运算符规则和隐式类型转换示例详解
Sep 06 Javascript
js get和post请求实现代码解析
Feb 06 Javascript
JS实现按比例缩小图片宽高
Aug 24 Javascript
js不常见操作运算符总结
Nov 20 Javascript
Bootstrap基本样式学习笔记之标签(5)
Dec 07 #Javascript
Bootstrap基本样式学习笔记之按钮(4)
Dec 07 #Javascript
jQuery中get方法用法分析
Dec 07 #Javascript
Bootstrap基本样式学习笔记之表单(3)
Dec 07 #Javascript
jQuery删除当前节点元素
Dec 07 #Javascript
概述如何实现一个简单的浏览器端js模块加载器
Dec 07 #Javascript
jquery 标签 隔若干行加空白或者加虚线的方法
Dec 07 #Javascript
You might like
PHP 5.0对象模型深度探索之对象复制
2008/03/27 PHP
PHP操作数组相关函数
2011/02/03 PHP
允许phpmyadmin空密码登录的配置方法
2011/05/29 PHP
又拍云异步上传实例教程详解
2016/04/19 PHP
适合PHP初学者阅读的4本经典书籍
2016/09/23 PHP
颜色选择器 Color Picker,IE,Firefox,Opera,Safar
2010/11/25 Javascript
电子商务网站上的常用的js放大镜效果
2011/12/08 Javascript
Jquery实现简单的动画效果代码
2012/03/18 Javascript
用js实现in_array的方法
2013/11/05 Javascript
JS动态添加与删除select中的Option对象(示例代码)
2013/12/20 Javascript
jQuery-ui引入后Vs2008的无智能提示问题解决方法
2014/02/10 Javascript
JS实现的文字与图片定时切换效果代码
2015/10/06 Javascript
Javascript的表单验证-初识正则表达式
2016/03/18 Javascript
jQuery validate验证插件使用详解
2016/05/11 Javascript
js事件委托和事件代理案例分享
2017/07/25 Javascript
jQuery实现表格冻结顶栏效果
2017/08/20 jQuery
jQuery实现鼠标响应式淘宝动画效果示例
2018/02/13 jQuery
React中阻止事件冒泡的问题详析
2019/04/12 Javascript
Vue.js构建你的第一个包并在NPM上发布的方法步骤
2019/05/01 Javascript
详解JavaScript 高阶函数
2020/09/14 Javascript
python类继承与子类实例初始化用法分析
2015/04/17 Python
Python2/3中urllib库的一些常见用法
2017/12/19 Python
Django学习教程之静态文件的调用详解
2018/05/08 Python
利用Python将文本中的中英文分离方法
2018/10/31 Python
pygame实现飞机大战
2020/03/11 Python
Django分组聚合查询实例分享
2020/04/29 Python
Python模块zipfile原理及使用方法详解
2020/08/04 Python
地图可视化神器kepler.gl python接口的使用方法
2020/12/22 Python
使用CSS Grid布局实现网格的流动
2014/12/30 HTML / CSS
奥林匹亚体育:Olympia Sports
2020/12/30 全球购物
工业学校毕业生自荐书
2014/01/03 职场文书
珍惜水资源建议书
2014/03/12 职场文书
片区教研活动总结
2014/07/02 职场文书
中学生教师节演讲稿
2014/09/03 职场文书
2014年财务经理工作总结
2014/12/08 职场文书
高一军训决心书
2015/02/05 职场文书