位置: 编程技术 - 正文

javascript 面向对象编程 function是方法(函数)(javascript面向对象编程指南 pdf)

编辑:rootadmin
好程序不是写给computer的,而是写给human的。遇到复杂功能,应该想着把它简化、组件化,把小功能封装成小组件,小功能块可以任意的组合得到千变万化的复杂功能。function就可以帮助我们把功能进行封装。那什么是封装呢。要我说,只要把具体实现给打包,对外提供调用接口那就是封装,方法也好、类也好就做了这些事。

javascript中的function可以用来创建方法、也可以用来创建类,实际上我们可以认为是用function来模拟出的类(说到类一般都会要去了解闭包的知识)。还是先看一下方法吧。

javascript函数分为有名函数、匿名函数和在匿名函数基础上延伸出来的立即执行函数。

普通函数就是用function直接声明的有名函数。

function Hello() { alert("hello , everybody!"); }; Hello(); function SayHelloTo(somebody) { alert("hello , " + somebody + "!"); }; SayHelloTo("张三");

上面分别创建了Hello和SayHelloTo方法。Hello不带有参数,直接通过Hello()来完成调用。SayHelloTo方法带有一个参数,向谁问候时需要知道是在问候谁。在调用SayHelloTo(“张三”)时要传入参数。这些代码和java、C#都没有什么太大区别。在方法重载上却有较大改变,javascript本身并不支持什么重载,一个方法名就对应一个方法。如果强制的写出多个同名方法,其实会出现先写的方法被覆盖掉的情况。

function Hello() { alert("hello , everybody!"); }; Hello(); function Hello(somebody) { alert("hello , " + somebody + "!"); }; Hello("张三");

第一个Hello方法被覆盖掉,执行时直接调用Hello()则认为调用第二个Hello方法但没有传递参数值,所以弹出了undefined信息。调用Hello(“张三”)时很正常的完成执行。其实javascript也可以用一些直白的方式来完成重载。学过C#的人都会知道有个params关键字,通过它可以实现向方法传递不定个数的参数。我们可以通过对参数的信息做手动的判断也可以模拟出类似重载的效果。而在javascript中根本就不需要什么params关键字,就可以很自然的实现任意个数参数的传递。function中有个arguments属性,可以把它看成一个数组,它按传递进来的参数的顺序来保存所有的参数。也就是说我们在定义方法时可以不声明参数名。

function ShowArguments() { var args = ""; for (var i = 0; i < arguments.length; i++) { args += arguments[i] + ","; }; alert(args.substr(0, args.length - 1)); }; ShowArguments(1, 2, 3, 4, 5, 6, 7);

试着用argements来模拟一下重载。

function Hello() { if (arguments.length == 0) { alert("hello , everybody!"); } else { alert("hello , " + arguments[0] + "!"); }; }; Hello(); Hello("张三");

基于参数个数不同的重载。

function Increase(arg) { if (typeof arg == "undefined") { alert("请输入参数"); } if (typeof arg == "string") { alert(String.fromCharCode(arg.charCodeAt(0) + 1)); } if (typeof arg == "number") { alert(arg + 1); } }; Increase(); Increase("a"); Increase(1); 基于参数类型不同的重载。

函数除了有名函数之外也可以是匿名函数,匿名函数就是没有名子的函数,不论函数有名还是没有名子,都是一个完整的函数对象。匿名函数还是用function来声明,但不用为它指定名称。其它的方面,比如参数等等和有名函数没什么区别。

function() { …… };

匿名函数一般可以满足临时的函数需求,不需要有变量对其进行引用(有名的函数可以认为是有变量引用的函数)。比如需要一个函数做为值对象做为参数传入方法、需要编程的方式为对象添加事件,用匿名函数都可以很好的完成。当然你也可以单独声明变量来引用某个匿名函数对象,这和普通有名函数就没什么区别了。

function Each(array, fun) { for (var i = 0; i < array.length; i++) { fun(array[i]); }; }; var nums = [1, 2, 3, 4, 5, 6, 7]; Each(nums, function(arg) { alert(arg); });

上面代码执行,依次输出数组中的元素。

//在窗体加载时,在标题上显示当前时间 window.onload = function() { document.title = new Date().toString(); }; //也可以将匿名方法传入定时器中 setInterval(function() { document.title = new Date().toString(); }, );

使用匿名函数绑定事件和进行定时操作。

var Hello = function() { alert("hello , everybody!"); };

如果将匿名函数赋给变量,那和有名的普通函数就没区别了。但不管是变量引用还是普通地有名函数,这样的函数在内存上都持久的占有一定资源。有时候我们只想执行一次大不必使用有引用的函数,直接执行匿名函数可能是最好的选择。把匿名函数包起来,加个括号执行,一切ok,这就是由匿名函数延伸出来的立即执行函数。

(function() { alert("hello , everybody!"); })(); (function(somebody) { alert("hello , " + somebody + "!"); })("张三");

立即执行函数在做事件绑定,设置回调函数等方面往往会有意想不到的效果,可以解决诸如对象引用等问题。

var student = { Name: "张三", Age: , Introduce: function() { alert("我叫" + this.Name + ",今年" + this.Age + "岁了!"); } }; window.onload = (function(obj) { return function() { obj.Introduce(); }; })(student);

因为javascript中函数的这些特点加之它的对象的特征,我们还可以写出一些有functional意味的程序出来。其实javascript中function真的是老大。

function Sum(fun, x) { if (x <= 0) return 0; return fun(x) + Sum(fun, x - 1); }; alert(Sum(function(i) { return i * i; }, ));

下面这又是什么呢?是方法吗?是类吗?

function Point() { };

先??碌秸猓?麓卧倏纯蠢唷?/P>

推荐整理分享javascript 面向对象编程 function是方法(函数)(javascript面向对象编程指南 pdf),希望有所帮助,仅作参考,欢迎阅读内容。

javascript 面向对象编程  function是方法(函数)(javascript面向对象编程指南 pdf)

文章相关热门搜索词:javascript面向对象编程 PDF,javascript面向对象吗,javascript面向对象编程 PDF,javascript面向对象编程,javascript面向对象编程,javascript面向对象编程,javascript面向对象编程,javascript面向对象吗,内容如对您有帮助,希望把文章链接给更多的朋友!

学习JS面向对象成果 借国庆发布个最新作品与大家交流 首先引入一个jQuery的小问题jQuery在设置透明度上是有问题的,首先看一下其代码:Code//IEusesfiltersforopacityif(!jQuery.support.opacity&&name=="opacity"){if(set){//IEhastro

面向对象的javascript(笔记) 一、引用//产生一个数组对象varitems=newArray('1','2','3');//使一个引用指向该对象varitemRef=items;items.push('4');//items与itemRef指向同一对象alert(items.length===itemRef.le

JavaScript 核心参考教程 内置对象 这个标准基于JavaScript(Netscape)和JScript(Microsoft)。Netscape(Navigator2.0)的BrendanEich发明了这门语言,从年开始,已经出现在所有的Netscape和Microsoft浏览器中

标签: javascript面向对象编程指南 pdf

本文链接地址:https://www.jiuchutong.com/biancheng/386497.html 转载请保留说明!

上一篇:javascript 面向对象编程 聊聊对象的事(javascript面向对象编程)

下一篇:学习JS面向对象成果 借国庆发布个最新作品与大家交流(js面向对象编程实例)

  • 材料抵扣货款怎么写简单协议范本
  • 申报社保不报个人账户
  • 去年收到一张普票超范围了怎么办
  • 企业所得税季度预缴怎么计算
  • 生产经营个人所得税退税流程
  • 出差补贴要不要发票
  • 印花税按照开票金额缴纳可以吗
  • 独立核算和非独立核算由谁定
  • 小规模纳税人租金发票的税率是多少
  • 工程会计和工业会计进销项区别是什么
  • 营业外收入在所得税表中填入哪个科目
  • 资产负债表应交税费期末余额是什么意思
  • 资产减值损失与资产处置损益区别
  • 销货清单是否需盖章
  • 坐收坐支在会计上如何反映
  • 业务招待费的扣除标准是什么2022
  • 应计利息会计分录处理
  • 物业公司需要向哪个部门缴费
  • 餐饮定额发票可以用吗现在
  • 减税降费在中国 应形成制度性
  • 月底结账哪些科目有余额
  • 工具器具属于固废吗
  • 个人所得税纳税比例
  • 不动产进项税为什么不能抵扣
  • 没有走公户的发票费用怎么做账
  • 其他应收款怎么冲平
  • 成本核算的一般步骤
  • 出租的土地
  • 在建工程可以计入资本性支出吗
  • 不良资产核销的条件 追偿180天
  • VS2022(Visual Studio)发布ASP.NET Core Web API应用到Web服务器(IIS)
  • php解析json对象
  • 慕尼黑基姆湖
  • 巴黎拉丁区有个著名的人文景点叫做先贤祠
  • 企业所得税核定征收方法有哪两种
  • php文件包含的4种方式
  • php函数写法
  • php 返回
  • 适用执行企业会计准则的一般企业
  • react 路由参数
  • yolov5 libtorch
  • commonjs的特点
  • vue的ref怎么用
  • echarts api文档
  • move命令移动文件夹下所有文件
  • 深入理解php
  • 取得增值税
  • python如何实现事务机制
  • 银行手续费和利息会计分录
  • 金税盘减免税款月末如何结转
  • 企业合并的流程
  • 去年多计提的所得税怎么处理
  • 冲减以前年度营业外收入分录
  • 负数发票作废后对原发票有影响吗
  • 机物料消耗计入什么费用
  • 员工宿舍发生事故赔偿吗
  • 合理损耗怎么算
  • 员工工资费用
  • sqlserver开启远程
  • 通过SQL绘制杨辉三角的实现方法介绍
  • sql sever使用教程
  • mysql开发语言
  • win8系统设置
  • win1020h2版好不好
  • windows8 8.1
  • vlcplayer最新版
  • javascript中的判断语句
  • jquery设置自定义属性
  • nginx1.16安装
  • linux用c语言实现命令功能
  • Android Studio 1.1.0 配置androidannotations框架
  • 小说温故知新
  • js实现盒子移动
  • jquery树形菜单
  • js实现隔行换色
  • jquery选项卡
  • 湖南省低保电话是多少?
  • 江苏医保给家人用怎么操作
  • 企业税收怎么收
  • 按照5%的征收率减按1.5%计算应纳税额是什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设