位置: 编程技术 - 正文

JS类定义原型方法的两种实现的区别评论很多(js 原型方法)

编辑:rootadmin
我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? JScript Class: Extends prototype method: Or # re: JS类定义原型方法的两种实现的区别 回复 更多评论 我先来说一个简单的区别:这两个方法导入的原型方法,第一个是一个匿名方法;第二个方法有方法名"JSClass.prototype.MethodA"。 -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 <BODY> <script> function JSClass() { } function = JSClass.prototype.MethodA() { }; </script> </BODY> 提示出错乜。 -- : | 阮 # re: JS类定义原型方法的两种实现的区别 回复 更多评论 faint,我发现FreeTextBox修改少量数据(一两个字符)提交有时会没有效果:( 我那个是手误多写了个"=",可是我记得我修改过了的。 -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 其实这两个原形定义方式可以简化一下来讨论,先把它们看作是两个函数,如下: Foo1(); function Foo1() { alert('This is Foo1.'); } 和 Foo2(); var Foo2 = function() { alert('This is Foo2.'); } 运行第一个显然是不会有任何错误的,可是运行第二个就有问题了,这时系统会说:Microsoft JScript runtime error: Object expected。这就是说函数定义(Foo1)在脚本解析器中有最高的初始化优先级,这个很好理解。如果不优先处理函数,那么对于函数中的函数调用就没有办法处理了,假使我们先定fn1()再定义fn2(),却从fn1中调fn2,那么就通不过解析了。为什么Foo2不能被初始化,Foo2的定义根本不是函数定义,它是一个标准的赋值语句,之所以能象标准函数一样的使用Foo2(Foo2()),完全是因为它指向的是一个函数对象的实例而已。 -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例: <script language="javascript"> function NormalClass() { this.m_Property1 = 'P1 in Normal Class.'; this.m_Property2 = 'P2 in Normal Class.'; this.toString = function() { return '[class NormalClass]'; } return new InnerClass(); function InnerClass() { this.m_Property1 = 'P1 in Inner Class.'; this.m_Property2 = 'P2 in Inner Class.'; this.toString = function() { return '[class InnerClass]'; } } InnerClass.prototype.Method1 = function() { alert(this.m_Property1); }; function InnerClass.prototype.Method2() { alert(this.m_Property2); }; } </script> 执行: var nc = new NormalClass(); nc.Method1(); nc.Method2(); 是什么效果?为什么? -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 最后结果居然是nc.Method1()没有定义,nc.Method2()运行正常。 其实不奇怪了,InnerClass.prototype.Method1 = function()依赖于赋值语句的执行,而 function InnerClass.prototype.Method2() 以最高优先级被脚本引擎初始化。 -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 我在Antechinus JavaScript Editor测试你的代码在: function InnerClass.prototype.Method2()报错, SyntaxError:missing( before formal parameters See: .prototype.Method2( -- : | Error # re: JS类定义原型方法的两种实现的区别 回复 更多评论 @Error 用IE来试过吗? -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 我用FF也是一样的报错: missing( before formal parameters See: .prototype.Method2( -- : | jzz # re: JS类定义原型方法的两种实现的区别 回复 更多评论 return new InnerClass(); 把这行移到 function InnerClass.prototype.Method2() { alert(this.m_Property2); }; 后面ie执行正常.FF报错: missing( before formal parameters See: .prototype.Method2( ie是安顺序执行下来的,而NS系列不是! FF在执行到function InnerClass.prototype.Method2() 这个的时候它根本不知道有这个InnerClass类,自然就不能无缘无故的来个prototype.xxx的东东 -- : | Doutu # re: JS类定义原型方法的两种实现的区别 回复 更多评论 @Doutu 把return new InnerClass();放到function InnerClass.prototype.Method2()这个方法之后,就完全违背了我编写这个示例的初衷。这个示例恰好说明了,IE对function foo()这种函数定义格式有较高的解析优先级,而foo = function()只是一个普通的赋值语句。至于ff中的情况我没有研究过,既然你说ff找不到return后的InnerClass,那么就说明是顺序的解析function foo()这种还属定义格式的。 -- : | birdshome # re: JS类定义原型方法的两种实现的区别 回复 更多评论 唉。可怜的只会用ie的人呀。 function x.y.z() {} 的写法根本就是不标准的写法,只有ie支持,其他js引擎中如ff或opera都会报错。符合标准的写法只有 x.y.z = function () {}; 当然,就语法层面来说,我挺喜欢这种写法的,希望以后的标准能采纳这种写法。 -- : | hax # re: JS类定义原型方法的两种实现的区别 回复 更多评论 呵呵 hax说得对啊。 只有ie才会像妈妈一样包容孩子的各种错误 标准的写法只有 x.y.z = function () {}; 其实,ie还支持更诡异的写法。 看看这个 function window::onload(){ alert("go_rush") } -- : | Go_Rush # re: JS类定义原型方法的两种实现的区别 回复 更多评论 @hax 标准再好,也是为人服务的,争论这个是学院派和工程派之间的事情,我们实现好我们自己系统就可以了,何必过分在神仙打架。 // 你的评论其实挺好的。Sigh,只可惜因为IE,我好可怜啊~~~

推荐整理分享JS类定义原型方法的两种实现的区别评论很多(js 原型方法),希望有所帮助,仅作参考,欢迎阅读内容。

JS类定义原型方法的两种实现的区别评论很多(js 原型方法)

文章相关热门搜索词:js定义类的三种方法,js 原型方法,js类定义的方法有哪些,js 原型方法,js的原型对象,js 原型方法,js 原型方法,js 定义类,内容如对您有帮助,希望把文章链接给更多的朋友!

一实用的实现table排序的Javascript类库 一个Javascript的类库,用于table内容排序。使用很方便,不用每次都去调用数据库了。特别适合多表查询的排序。加上tbody的style.display切换,也可以实现

js类后台管理菜单类-MenuSwitch 写MenuSwitch类的出发点是因为随着后台管理项越来越多,从而导致菜单显示部出现了滚动条导致页面很不美观,自己蒙生写这个JS类了。这个功能类采用

js定义对象简单学习例子 无标题页[Ctrl+A全选注:如需引入外部Js需刷新才能执行]

标签: js 原型方法

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

上一篇:js类中获取外部函数名的方法与代码(外部js获取当前vue实例)

下一篇:js类后台管理菜单类-MenuSwitch(js写后端用什么框架)

  • 保险税优识别码是保单号吗
  • 生产成本月末有余额怎么结账
  • 开广告公司需要营业执照吗
  • 小规模纳税人小微企业免税销售额
  • 合伙企业的合伙协议
  • 购买折让
  • 当月计提的工资与次月发放数不同
  • 电子商务支付平台有哪些
  • 贷款计提利息会计分录
  • 广告费支出限额
  • 非盈利组织一般纳税人应交的税
  • 工程发票没写经办人没写可以吗
  • 所得税退税需要多久
  • 企业上月份销售收入在本月份发生销售折让时
  • 简易计税开票开成了一般计税的税率会比对不通过吗
  • 赠品怎么做账务分录
  • 小规模纳税人申报
  • 原材料当做废品怎么做
  • 商品购进核算
  • 利尼扬蒂野生动物保护区中的一只雄性豹子,博茨瓦纳 (© Karine Aigner/Tandem Stills + Motion)
  • PHP:finfo_file()的用法_fileinfo函数
  • 未履行的应税合同缴纳印花税
  • Cusco Cathedral on the Plaza de Armas, Cusco, Peru (© sharptoyou/Shutterstock)
  • php 使用 AWS kinesis
  • 安斯海滩上的角眼沙蟹,塞舌尔普拉兰岛 (© Ingo Schulz/Offset by Shutterstock)
  • vue3封装axios
  • vue路由跳转的三种方法
  • 微信小程序开发公司
  • 中国移动常被称为
  • win11预览版22000.51
  • php提供的三种在函数内使用全局变量的方式
  • 美国人用什么英语词典
  • 小规模纳税人减按1%账务处理
  • 进口货物交哪些税费
  • 残疾人保证金的滞纳金怎么计算
  • 物业管理公司的主管部门是哪个单位
  • 社保应该怎么计提
  • 老板出差司机住哪
  • 收到缴纳个人所得税短信
  • 信用减值损失在贷方表示什么
  • 金税四期监控银行卡
  • 建筑劳务公司是什么性质
  • 商品损耗进项税额怎么算
  • 材料暂估入库的账务处理
  • 开出去的发票没有进项发票如何核算成本?
  • 专利权转让的条件
  • 公司给别人公司过账应该注意哪些
  • 网上银行回单可以做账吗
  • 外币应收账款汇兑损失计入财务费用吗
  • 子公司利润母公司还有其他方式吗
  • 资产负债表负债率怎么计算
  • 房地产企业预付账款会计分录
  • 商场水电费应该由谁承担
  • 利润表增加,资产负债表减少怎么回事
  • 公司法人可以变更给老人吗
  • sqlserver存储过程在哪里
  • sql数据库连不上可能的原因
  • mysql查询语句大全及用法
  • winxp系统如何安装
  • xp系统注册表空白怎么办
  • windows vista(service pack1)
  • 东芝笔记本图片及型号
  • win10系统如何查看激活状态
  • windows10 rs2
  • linux px
  • win8使用教程和技能
  • mac怎么旋转窗口
  • 怎么安装多个相同软件
  • 360tray占用大量内存
  • linux特殊权限命令
  • 电脑开机后出现win7画面后一直黑屏
  • win7系统怎么禁止更新
  • python os.path模块
  • html5仿微博代码
  • python的threading模块详解
  • Android本地文件怎么显示歌词
  • PreferenceActivity与PreferenceFragment应用
  • 湖北国税办税人是谁
  • 初始密码是几位数
  • 加拿大的环保
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设