JavaScript本身并不是设计成面向对象的,所以没有class之类的关键字用来定义类,但JavaScript本身相当灵活,可以利用function关键字来定义类并创建对象。JavaScript定义类是有多种方式的,这里只详细介绍最常用的一种。 一、定义类并创建实例 function MyClass() { this.id = 5; this.name = 'myclass...'; } 这样,我们就定义了一个MyClass类,里面有两个公共属性 id 和 name。其中this关键字表示当前对象,类似于C#等强类型语言。 注意:列出属性的同时必须对属性进行赋初值,这样JS才会将其解释为对象的属性。 接下来我们可以这样定义类的实例(其中 new 不可省略): var my = new MyClass(); 并以下列形式访问类属性: my.id 二、定义公有属性和私有字段 在function中,用var定义的变量为私有变量,可以理解为类的私有字段。 用this定义的变量为公有属性。 function MyClass() { this.id = 5; var name = 'myclass...'; } my = new MyClass(); alert(my.id); alert(my.name); //结果 // 5 // undefined 三、定义公有方法和私有方法 同样的,用var定义的方法为私有方法,用this定义的方法为公有方法。 function myClass() { this.id = 5; this.alert = function(msg) { window.alert(msg); } } my = new myClass(); my.alert('the function alert is called...'); //结果 // the function alert is called... 如果将上述代码的 this.alert = function(msg) 改成var alert = function(msg),那么就不能用my.alert来调用这个方法了。私有方法只能供类内部的其他方法调用。 定义公有方法(实例方法)还有另一种形式,就是利用 prototype 属性, 其实prototype 属性还可以用来扩展内置类的实例方法的,比如去掉字符串两边空格的 trim 方法:String.prototype.trim = function() { return ... } function myClass() { this.id = 5; } myClass.prototype.alert = function(msg) { window.alert(msg); } var my = new myClass(); my.alert('the function alert is called...'); 将和上面显示同样的结果。 四、构造函数 新建对象(my = new myClass();)和调用函数(myClass())是相似的,所以我们自然想到为函数添加一些参数,在调用此函数时输入一些参数。新建对象也是一样的。看下面的示例: function myClass(id, name) { this.id = id; this.name = name; } var my = new myClass(5, 'test name ...'); alert(my.id); alert(my.name); //结果 // 5 // test name ... 这样定义的构造函数有个局限性,实例化对象的时候如果没有传参数,或少传参数,那么没有实参的参数值将会是undefined,比如将上面代码的对象实例化改为:var my = new myClass(5); 输出结果将会变成: // 5 // undefined 为了让属性具有默认值,比如 int 默认是 0 ,可以采用以下方法,虽然比较麻烦。 function myClass(id, name) { this.id = 0; //整型默认为0 this.name = ''; //字符串默认为空字符串 if (id != null) { //当 id=undefined 时 id==null 依然为true this.id = id; } if (name != null) { this.name = name; } } var my = new myClass(); alert(my.id); alert(my.name); //结果 // 0 // (空字符串) 这样的情况下,延伸出另一个问题,就是你无法在构造函数中初始化 id 为 null 。 总之,一切看个人需要,灵活应用便是。 五、静态属性和静态方法 静态的属性和方法是在定义了类之后定义的。如下例: function myClass() { this.id = 5; } myClass.count = 0; //静态属性 myClass.staticFun = function() { //静态方法 alert(++myClass.count); } var my = new myClass(); alert(my.id); //用实例访问实例属性 alert(myClass.count); //用类名访问静态属性 myClass.staticFun(); //用类名访问静态方法 //结果 // 5 // 0 // 1 六、类的继承 在JS中实现类的继承,实际上是用到了类的另一种创建方式,先创建基类的一个对象,再为这个对象添加新的属性和方法,然后再返回这个对象。 在这里先不讨论这种创建对象的方法。 function baseClass() { this.id = 5; } function myClass() { var my = new baseClass(); my.name = 'className'; my.testFun = function() { alert(my.name); //this.name 也可以 } return my; } var my = new myClass(); alert(my.id); alert(my.name); my.testFun(); // 结果 // 5 // className // className // 七、类的扩展 function baseProcess(){} baseProcess.prototype.controlState = function(outerParam,num,newList){ } //继承方法2 // function base(){} base.prototype.fun=function(){alert('base');} function child(){} child.prototype= new base; child.prototype.controlDisplay=function(outerParam){ } child.prototype.fun=function(){alert('child');}//方法重写 // 八、结构体\枚举 // var structs={ ID:id, NAME:name } structs.ID; var structs={ "ID":id, "NAME":name } structs["ID"];
发表评论
-
转载:jquery webservice 跨域
2013-01-28 16:06 1289现在的JQuery中$.ajax方法支持跨域读取json数 ... -
变更地址栏参数
2011-09-14 10:06 822<html> <head ... -
仿google 日历
2011-08-24 23:10 903仿google 日历仿google 日历仿google 日历仿 ... -
Jquery fullcalendar 官方中文文档
2011-08-22 08:47 25121. 使用方式, 引入相关js, css后, $(‘#div_ ... -
js webservice
2011-05-12 08:50 11101. 创建webservice,为了免于落俗我稍稍修改了 ... -
光标位置函数
2010-12-16 12:44 811function getCursortPosi ... -
select元素javascript常用操作
2010-12-14 09:32 654东西很简单,只是自己记性不好,经常忘记一些关键字 所以发 ... -
cookie
2010-09-17 09:06 701function SetCookie(CookieNa ... -
webservice and js
2010-06-24 09:17 843jQuery调用WebService网上的介 ... -
jsxiaoguo
2009-05-14 10:52 739jsxiaoguo -
窗体大小
2009-05-12 09:39 904网页可见区域宽:document.body.clientWid ... -
闭包小例
2009-02-05 08:53 751//A是一个普通的函数 ... -
js other event target
2008-11-20 14:41 1152解耦导航模式 function Onclick(evt) ... -
用 javascript 处理 JSON
2008-11-19 14:33 1308用 javascript 处理 JSON 关键字: json ... -
js 倒计时
2008-11-13 09:28 988<!doctype html public " ... -
Javascript中最常用的55个经典技巧
2008-09-27 17:47 8821. oncontextmenu="window.e ... -
js xml
2008-09-17 10:53 1220loadXML = function(xmlFile) ... -
正则表达式
2008-09-12 09:04 829数:44] //校验是否全由数字组成 function ... -
js 函数
2008-09-11 13:12 8191.document.write(""); ... -
js 验证函数
2008-09-11 13:03 711Javascript函数大全 /* ---------- ...
相关推荐
JavaScript,简称JS,是一种广泛用于Web开发的轻量级...通过学习以上知识,并结合"3d_js"文件中的示例,开发者可以逐步掌握JavaScript实现3D效果的技术。不断实践和探索,可以创造出更多令人惊叹的3D交互式网页应用。
标题中的“js提示框-转载+++ js 乱码+++自动提交+滚动图片加载+箭头导航(转载)”表明这篇内容涵盖了多个JavaScript相关的知识点。这里我们将分别解析这些关键点,并深入探讨它们。 首先,"js提示框"指的是...
该案例仅在mapview下有效,sceneview就不显示了,下面将结合threejs对该案例进行修改,实现sceneview下的三维动态线图层。 实现过程请看博客原文。 ———————————————— 版权声明:本文为CSDN博主「...
【纯js写的一行多图轮播】是一种常见...通过上述知识点的学习和实践,开发者可以创建一个纯JavaScript实现的一行多图轮播组件,无需依赖任何外部库或框架,提高页面加载速度,同时也能更好地控制和定制轮播的各个细节。
JavaScript,作为浏览器端的主要脚本语言,被广泛用于实现这些动态效果。本篇文章将详细探讨如何使用JavaScript,结合jQuery库,来实现数据的分页显示以及表格内容的排序。 **一、排序** 在JavaScript中,数组的...
在给定的资源中,"javascript中文转拼音(转载)"是一个关于使用JavaScript实现中文字符转换为拼音的功能。这个功能在多种场景下都非常有用,比如搜索引擎优化(SEO)、语音合成或无障碍阅读等。 `pinyinEngine.full....
标题“JS高手做的”暗示了这是一个使用JavaScript编程语言完成的项目或应用,而描述中的“全部用JS完成,一个JS高手做的,特转载”进一步强调了这个项目完全依赖JavaScript技术,并且是由一位经验丰富的JavaScript...
现有的JS代码压缩工具都是网页版的,例如ESC,shrinksafe等,他们都是在网页上用js本身实现对代码的压缩。由于网页的局限性,很难很好的管理压缩任务。聚问网络开发的js压缩专家(JsPacker)v1.0 是同功能的桌面程序,...
#### JavaScript实现 ```javascript function getIE(e) { var t = e.offsetTop; var l = e.offsetLeft; while (e = e.offsetParent) { t += e.offsetTop; l += e.offsetLeft; } alert('top=' + t + '\nleft='...
现有的JS代码压缩工具都是网页版的,例如ESC,shrinksafe等,他们都是在网页上用js本身实现对代码的压缩。由于网页的局限性,很难很好的管理压缩任务。聚问网络开发的js压缩专家(JsPacker)v1.0 是同功能的桌面程序,...
通过`onMouseOut`和`onMouseOver`事件,可以实现鼠标悬停时元素颜色的变化: ```html 按钮" name="B1" onMouseOut="this.style.color='blue'" onMouseOver="this.style.color='red'" class="button"> ``` ### 4. ...
- 每种工具类都拥有对应的选项类(Options)来设置属性,以及工具类(Tool)来实现具体功能。 4. **叠加物**:为在地图上添加覆盖层提供了方法,如图标、标记点、文字标签、折线、多边形等。 - 例如**TOverlay类...
2.可以对自己写的javascript代码进行正规的对齐缩进,解决了dotnet无法实现的功能.当然同样适用于C/C#/Java/Php等代码的自动缩进. 3.对组合成一行的js代码自动进行缩进,形成多行. 4.对加密的js代码进行解密(暂未制作)...
另一种更简洁的实现方式是使用数组来存储星期的名称,然后通过`getDay()`返回的数字作为索引来获取对应的星期名称: ```javascript var days = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", ...
本项目利用layui-progress、element、jQuery和JavaScript技术,巧妙地设计了一个动态进度条,旨在提供一个易于学习的示例。 layui-progress是layui框架中的一个组件,它提供了丰富的进度条样式和自定义选项。layui...
转载者最起码注明作者和出处!http://www.cnblogs.com/GuominQiu 代码如下: //————————————————————————— //判断日期格式是否正确 //返回值是错误信息, 无错误信息即表示合法日期字符串 ...
1、用JS实现和google地图一样的地图--拖动,移动,放大、缩小、还原 2、不需搭建gis服务器,不需第三方API支持。 3、地图的图片直接从百度地图中选择所需的比例,直接截图,然后PS拼接一下就OK了(示例为福州市地图)...
(可以翻我7月的文章里有此动画的注) 用前端三大杀手HTML+CSS+JS实现超炫酷高级感的动态圣诞树动画效果,只需要CV就可以了,有粒子特效动画卡片等特效。(我在七月就发布过了,有人盗我的项目发出去但是没有标明...