javascript面向对象入门基础详细介绍


Posted in Javascript onSeptember 05, 2012

什么是对象

简单点说,编程语言中的对象是对现实中事物的简化。例如,我们一个人就是一个对象,但是编程语言很难完全描述一个这样复杂的对象。所以我们必须做出简化,首先,将人简化成属性和行为的组合,然后仅仅保留对程序有意义的几个属性以及行为。例如,我们做一个统计某学校的人的身高的程序,那么我们在这个程序中就可以把人的行为省略掉,只保留行为,并且只保留身高这一个属性。这样,我们就得到了一个最简单的对象。

JavaScript字符串对象

对象的属性
其实我们之前在HTML DOM中已经就是在使用对象了。例如,我们知道,DOM节点有一些信息、例如nodeName、nodeType等,其实这些信息就是节点对象的属性。下面我们以字符串为例来看看对象的属性。

字符串的属性
var s = "我有个7个字符";定义了s这个字符串之后,我们就有了一个字符串对象,我们可以访问它的长度属性(length),这个属性不需要我们定义,它是一个内置的属性。访问的方式如下:

s.length点击下面的按钮看看字符串的长度。

alert(s.length)
字符串对象的方法(行为)
同样,对象也可以有行为,以字符串对象为例,我们可以让字符串返回某一个位置的字母或文字,这就是一个行为。可以用后面的按钮简单地体验一下字符串的各个属性与方法,本文最后会详细地解释各个方法的使用方法。

<script type="text/javascript">
var s = "我有个7个字符";var str = "字符" + "串"; //两个字符串相加
alert(str) 
</script>

使用字符串的length属性为字符串的长度。

alert(str.length)
使用charAt方法返回指定位置的字符。

alert(str.charAt(0))
alert(str.charAt(1))

substring方法从字符串中截取一个子字符串。

alert(str.substring(0,2))
indexOf返回字符串中指定字符或字符串的位置,如果字符不存在就返回-1。

alert(str.indexOf('符')
lastIndexOf方法返回一个字符串中某字符最后一次出现的位置。

date对象

实例JavaScript date代码
我们先来看一段使用了date对象的JS代码。点击下面的几个按钮就可以看到各个变量的值了。

<script type="text/javascript"> 
var today = new Date(); //新建一个Date对象 
var todayStr = today.toString();//把日期转化为字符串 
var todayLocal = today.toLocaleString();//转换为本地字符串 
var date = today.getDate();//查询当月日期 
var day = today.getDay();//查询当前星期几 
var month = today.getMonth();//查询月份 
var year = today.getFullYear();//查询年份 
alert(todayStr); 
alert(todayLocal); 
alert(date); 
alert(day); 
alert(month); 
alert(year); 
</script>

新建一个Date对象
我们使用如下这个语句来创建一个Date对象。

var today = new Date();执行之后,today变量里就保存了创建的Date对象。

字符串对象的方法(行为)
JavaScript date对象查询(get)方法
JavaScript date对象设置(set)方法
JavaScript date对象转换(to)方法
JavaScript Date对象应用实例——时钟代码
本代码转自w3schools.com。

<script type="text/javascript"> 
function startTime(){var today=new Date(); 
var h=today.getHours(); 
var m=today.getMinutes(); 
var s=today.getSeconds();//当数字小于10的时候在前面加一个0 
m=checkTime(m);s=checkTime(s); 
document.getElementById('clock').innerHTML=h+":"+m+":"+s;//每隔500毫秒重新执行一次 
startTimet=setTimeout('startTime()',500);} 
function checkTime(i){ 
if (i<10){ 
i="0" + i; 
} 
return i; 
} 
</script>

数组对象

创建一个JavaScript数组

<script type="text/javascript"> 
//笨方法 
var arr = new Array("HTML","CSS","JavaScript","DOM"); 
//省事一点的方法 
var arr = ["HTML","CSS","JavaScript","DOM"]; 
与字符串对象一样,数组也有一个length属性,不过它的意思是数组包含元素的个数。点击下面的按钮可以看到arr的长度为4。 
alert(arr.length) 
</script>

实例JavaScript数组代码

下面是一段简单的使用数组的JS代码,可以点击后面的按钮来观察各个变量的值。

<script type="text/javascript"> 
var arr = new Array("HTML","CSS","JavaScript","DOM"); 
var arr2 = new Array("ASP.NET","PHP","J2EE","Python","Ruby"); 
var joinArr = arr.join(); 
var bigArr = arr.concat(arr2); 
var sortArr = bigArr.sort(); 
</script>

arr[n]返回数组指定位置的元素,n叫做下标,从0开始。 可以点击下面的按钮来查看arr各个位置上的元素。
alert(arr[0]) //位置0,也就是第一个元素 
alert(arr[1]) 
alert(arr[2]) 
alert(arr[3])

从上面的代码可以看到,在调用了数组的几个方法之后得到了joinArr、bigArr、sortArr这几个变量,这些方法将在后面具体介绍。可以先观察变量的值来猜猜这些方法的作用。

数学对象
例JavaScript Math代码

<script type="text/javascript"> 
var num = Math.PI; 
var rNum = Math.round(num);//四舍五入 
</script>

我们首先吧Math.PI的值保存在num中,这是一个JS内置的常量,可以点击下面的按钮来查看它的值。
alert(num)
rNum则是num经过四舍五入的值。

alert(rNum)
random方法则产生一个0-1之间的随机值。试着多点击几次下面的按钮,可以发现得到的数字会不断改变。

alert(Math.random())

函数对象

在JavaScript中,函数也是对象,我们使用下面以下语句定义一个函数的时候,其实是定义了一个Function类型的对象。

function add(a,b){ 
return a+b; 
}

为了说明这个问题,我们可以使用Function的构造函数来定义一个add函数:
<script type="text/javascript"> 
var add = new Function('a','b','return a+b'); 
alert(add(1,2)); 
</script>

使用这种方法定义的函数和上面的函数完全一样,不过这种语法比较麻烦,一般不会使用。
(函数)Function对象的call方法
call是一个非常有用的方法,它可以控制函数的运行环境,即控制函数内部this所指向的对象。下面的例子可以说明这个问题:
function whatsThis(){ alert(this); }我们调用以上函数的时候,将会看到this指向的是window,实验一下:
whatsThis()
但是如果使用call,我们则可以控制函数内部this的指向,例如:
whatsThis.call(document)()
以上代码使用function对象的call方法将函数内部的this指向了document。
如果原来的函数需要接受参数,例如add函数,可以使用如下形式:
add.call(document,1,2)也就是说,call的第一个参数是要绑定给this的对象,而1和2则是原来的add函数需要接受的参数。
(函数)Function对象的apply方法
apply的使用方法与call基本一致,只是参数是以数组的形式传递的,还是以add函数为例:
add.call(document,[1,2])可以看到,原函数add需要接受的两个数字参数是以一个数组的形式传递进apply的。
(函数)Function对象的caller属性
function whoCalls(){ alert(whoCalls.caller); } function SheCalls(){ whoCalls(); }whoCalls()SheCalls()
使用caller属性,可以了解谁调用了当前函数。注意,只有在函数体内部caller才有效。
(函数)Function对象的arguments属性
javascript的函数可以接受任意数量的参数,所以定义的时候,参数的个数作并不会限制函数的这个能力。在函数中,我们可以使用arguments来访问传入函数的参数,例如:
function howmany(){ var num = arguments.length; alert(num); }howmany函数会输出传递如函数参数的个数,点击下面的连个按钮试验一下。
howmany(1,2,3,4)howmany(1,2,3,4,5,6,7,8)
函数arguments.callee
我们已经知道function会有arguments属性,而arguments.callee则是当前正在执行的函数,例如:
function whoAmI(){ alert(arguments.callee); }whoAmI()
执行以上函数会显示出当前函数的源代码。当然了,我们可以再次调用callee,这主要用于匿名函数递归。
Javascript 相关文章推荐
服务端 VBScript 与 JScript 几个相同特性的写法 By shawl.qiu
Mar 06 Javascript
Eclipse去除js(JavaScript)验证错误
Feb 11 Javascript
DOM基础教程之模型中的模型节点
Jan 19 Javascript
jQuery左右滚动支持图片放大缩略图图片轮播代码分享
Aug 26 Javascript
谈一谈jQuery核心架构设计
Mar 28 Javascript
让浏览器崩溃的12行JS代码(DoS攻击分析及防御)
Oct 10 Javascript
Js自定义多选框效果的实例代码
Jul 05 Javascript
基于JavaScript实现微信抢红包功能
Jul 20 Javascript
vue-cli之router基本使用方法详解
Oct 17 Javascript
JavaScript中的null和undefined用法解析
Sep 30 Javascript
react 不用插件实现数字滚动的效果示例
Apr 14 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
Aug 03 Javascript
说说JSON和JSONP 也许你会豁然开朗
Sep 02 #Javascript
自己实现string的substring方法 人民币小写转大写,数字反转,正则优化
Sep 02 #Javascript
Javascript中的delete介绍
Sep 02 #Javascript
JS判断当前日期是否大于某个日期的实现代码
Sep 02 #Javascript
Javascript this 的一些学习总结
Aug 31 #Javascript
javascript动画浅析
Aug 30 #Javascript
jquery方法+js一般方法+js面向对象方法实现拖拽效果
Aug 30 #Javascript
You might like
下载文件的点击数回填
2006/10/09 PHP
PHP 截取字符串专题集合
2010/08/19 PHP
解决laravel5.4下的group by报错的问题
2019/10/16 PHP
Prototype Selector对象学习
2009/07/23 Javascript
javascript cookies操作集合
2010/04/12 Javascript
imgAreaSelect 中文文档帮助说明
2011/10/08 Javascript
ASP.NET jQuery 实例12 通过使用jQuery validation插件简单实现用户注册页面验证功能
2012/02/03 Javascript
js操作label给label赋值及取label的值示例
2013/11/07 Javascript
jquery实现更改表格行顺序示例
2014/04/30 Javascript
window.print打印指定div指定网页指定区域的方法
2014/08/04 Javascript
使用Xcache缓存器加速PHP网站的配置方法
2017/04/22 Javascript
微信小程序之购物车功能
2020/09/23 Javascript
JS自定义函数实现时间戳转换成date的方法示例
2017/08/27 Javascript
vue2.0实现移动端的输入框实时检索更新列表功能
2018/05/08 Javascript
react build 后打包发布总结
2018/08/24 Javascript
区别JavaScript函数声明与变量声明
2018/09/12 Javascript
KnockoutJS数组比较算法实例详解
2019/11/25 Javascript
vue-cli3单页构建大型项目方案
2020/04/07 Javascript
vue页面引入three.js实现3d动画场景操作
2020/08/10 Javascript
vue select 获取value和lable操作
2020/08/28 Javascript
element-plus一个vue3.xUI框架(element-ui的3.x 版初体验)
2020/12/02 Vue.js
mustache.js实现首页元件动态渲染的示例代码
2020/12/28 Javascript
[53:52]OG vs EG 2018国际邀请赛淘汰赛BO3 第二场 8.23
2018/08/24 DOTA
Python实战之制作天气查询软件
2019/05/14 Python
Python的几种主动结束程序方式
2019/11/22 Python
python中有函数重载吗
2020/05/28 Python
HTML table 表格边框的实现思路
2019/10/12 HTML / CSS
Michael Kors加拿大官网:购买设计师手袋、手表、鞋子、服装等
2019/03/16 全球购物
工程项目建议书范文
2014/03/12 职场文书
机关单位动员会主持词
2014/03/20 职场文书
2014世界杯球队球队口号
2014/06/05 职场文书
退学证明范本3篇
2014/10/29 职场文书
离婚财产分割协议书
2015/08/11 职场文书
2016年第二十届“母亲节暨幸福工程救助贫困母亲活动日”活动总结
2016/04/06 职场文书
Python函数式编程中itertools模块详解
2021/09/15 Python
教你使用RustDesk 搭建一个自己的远程桌面中继服务器
2022/08/14 Servers