位置: 编程技术 - 正文

JS 创建对象(常见的几种方法)(js创建对象的方法有哪些)

编辑:rootadmin
贴个代码先: function O(user,pwd){ //use constructor this.user=user; this.pwd=pwd; this.get=get; return this; } function O2(user,pwd){ //use factory var obj=new Object(); obj.user=user; obj.pwd=pwd; obj.get=get; return obj; } function O3(){ //use prototype } O3.prototype.user='abc'; O3.prototype.pwd='dis'; // O3.propotype.get='get'; //O3.prototype.get(){ //alert(this.pwd); //} function O4(user,pwd){ this.user=user; this.pwd=pwd; return this; } O4.prototype.get=function(){alert('');} //function get(){ //alert("This User:"+this.user); // } function test2(){ //var a=new O2('Us','Pw'); use factory & constructor //var a=new O3(); //use prototype //a.get(); var a=new O4('*U4','P4'); //混合 //a.user='Not ABC'; //set new property //alert(a.user); a.get(); } 常用的MS 就这几种,可能还有其它的.碰到再说吧.... 题外话:昨天手欠,试图用alert(window.appName)到ff之下去查看浏览器版本,结果弹出的竟然是Netscape,咋不是 firefox。继而又跑去chrome下试验,又一次弹出了Netscape。baidu搜 Netscape 竟然发现js就出自Netscape公司。惭愧啊惭愧!!!研究了这么久的js都不认识祖师爷。于是又跑去找了找族谱,原来js出自Brendan Eich之手,年他创造js时候,也不过就岁。哎呀,真是白活了,如他一般老的我,到现在都学不会js,真是人比人气死人。。js当初设计的时候,没有想到自己能从一部打电话用的手机变成集拍照,上网,游戏,电话于一身的智能机。真是造化弄人!!!也许各中的神奇,连Brendan Eich本人都没有想到。应该说Brendan Eich创造了js,而一大批的js牛人成就了今天如此复杂的js。 js不是木有类么?没关系,人家不是设计了原型属性么~ js不是木有块级作用域么?没关系,人家不是有作用域链么~ js怎样实现成员变量私有化?哦,用闭包解决吧~ 哦,这么多基本概念,彻底的晕掉了,路漫漫其修远兮。 言归正传,本文讨论几种js创建对象的方法,先从最好理解的工厂模式开始: 这里先定义o为一个空的对象,然后为o设置了一堆属性。其实也可以直接给o属性的嘛,所以如果这样写也是ok的。 还有一种办法是利用无敌的this,因为this就表示当前运行时的对象,将构造函数this的作用域指向新对象,将当前运行对象的属性和方法都赋给新对象,这样对象模式称为构造函数模式 在这个例子中,tanya和ansel都有一个constructor属性,该属性指向person。 考虑一下如下的情况: 发现两次弹出的都是ansel,这是因为不用new的话,就不是一个person的实例,而仅仅在执行函数。而在全局作用域调用一个函数时this总是指向Global对象。而Global对象在浏览器中就是window对象。 我们还可以用构造模式在另外一个对象中调用sayName方法,还记得Apply和call么,来吧再考虑另外一种情况, 原型模式就要考虑原型链了,分析一下,sayName方法在实例中被重复定义了两次,但其实没有必要创造两个一样的副本。使用原型方法,可以使是tanya和ansel的共享一个sayName方法。 于是原型模式的写法如下: 实际应用时,不是一成不变的套用某种模式,活学活用。需要共享方法的时候就用原型模式,需要使用副本的时候就用构造模式,还可以结合起来,把所有信息都封装在构造函数中,而通过在构造函数中初始化原型,使得对象保持了同时使用构造函数和原型的优点。

推荐整理分享JS 创建对象(常见的几种方法)(js创建对象的方法有哪些),希望有所帮助,仅作参考,欢迎阅读内容。

JS 创建对象(常见的几种方法)(js创建对象的方法有哪些)

文章相关热门搜索词:js创建对象的方式,js创建对象的两种方法以及区别,js创建对象有几种方式,js中创建对象,js创建对象的三种方式,js创建对象的三种方式,js创建对象有几种方法,js创建对象有几种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

JS 继承实例分析 functionP(name){this.name=name;this.p1=function(){alert('ParentConstructor');}returnthis;}functionC(name,id){//this.method=P;//this.method(name);//1stmethod//P.call(this,name);//2ndmethodP.apply(this,

Javascript 对象的解释 所有的构造器都是对象,而并非所有的对象都是构造器.每个构造器都有一个用来实现原型继承、共享属性的Prototype属性。对象通过new表达式创建;比如

js继承 Base类的源码解析 //timestamp:Tue,May::/*base2.js-copyright,

标签: js创建对象的方法有哪些

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

上一篇:jabsorb笔记_几个小例子第1/2页

下一篇:JS 继承实例分析(js实现继承的几种方式详述(推荐))

  • 个人私活 要交个人所得税吗
  • 滑准税是指关税的税率
  • 酒店维修费计入什么费用
  • 银行贷款第三方收款人
  • 增值税起征点的规定只适用于
  • 发票右上角打印缺数字
  • 买车装具
  • 公司投标成功
  • 淘宝店注册公司流程
  • 公允价值变动损益是什么意思
  • 车辆购置税计税价格含增值税吗
  • 购进生产用原材料,取得增值税专用发票注明税额25600元
  • 房屋对外投资
  • 费用摊销的常用方法有哪些
  • 今年交去年的工会经费账务处理?
  • linux命令执行成功后会返回什么
  • 路由器死机的表现
  • 财政拨款结余的明细科目
  • 备用金包括哪些大类
  • 公司一般账户不用了会怎么样
  • 公司付款给个人,怎么处理
  • word基本怎么使用
  • 当月交当月社保费会计分录
  • win10下载的软件打不开
  • 待抵扣进项税额和待认证进项税额的区别
  • PHP:oci_fetch_row()的用法_Oracle函数
  • 用银行存款支付本季度短期借款利息
  • mmc.exe是什么
  • window7怎么开机
  • php从哪里开始学
  • 文本生成图像前景怎么样
  • ps卸载没反应
  • 保教费收入要交企业所得税吗
  • 什么经营范围是营业执照
  • 加计扣除进项税额是什么意思
  • 所得税费用本期金额怎么算
  • 公司收到注册资本金需要做哪些呢
  • 购买方已抵扣怎么做分录
  • 专项附加可以叠加吗
  • 企业取得投资收益要交税吗
  • 增值税防伪税控系统
  • 购买土地缴纳契税会计分录
  • 招待客户的住宿费发票可以报销吗
  • 保险费用缴纳
  • 企业代扣代缴个税
  • 外地预缴个人所得税凭证怎么弄
  • 咨询服务费可以全额扣除吗
  • 公司账户可以转个人支付宝吗
  • 公司办理网银
  • 对公账户分为几类
  • 库存商品的成本
  • 生产车间的保险有哪些
  • 装修公司开劳务发票会被罚款吗
  • 银行利息收入的会计分录怎么写
  • 代理返利什么意思
  • 个人银行帐户可以代理销户吗?
  • 内部无形资产交什么税
  • 以前年度损益调整怎么做账
  • 出租人融资租赁的判断标准
  • 计算机彻底删除文件的方法
  • ubuntu笔记软件
  • linux中如何配置环境变量
  • win7guest账户有密码吗
  • wind移动版
  • 深入分析南水北调工程面临的新形势心得体会
  • node.js go
  • linux pymol
  • javascript:void(0)的作用示例介绍
  • android开源项目在哪找
  • 也论主板的扩展性
  • jquery 输入框输入完触发事件
  • jquery动态设置div高度
  • c# datetime.date
  • js判断iframe是否加载完成
  • 广东增值税电子专用发票
  • 小规模纳税人无进项发票要如何做账?
  • 政府主管部门对企业检查要求
  • 留学生在美国买房子需要什么条件
  • 税控发票开票软件金税盘版发票未报送什么情况?
  • 预付建造固定资产的工程价款
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设