27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]
E-mail:mzze@163.com
Q Q:32362389
W X:xiaomi168527
27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]
大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]
E-mail:97157726@qq.com
Q Q:97157726
给字符串对象 String 扩展一个方法(为了以后,可以直接使用)
让我们通过一个案例来认识为内置对象扩展方法
将一个字符串首字母大写,其他小写
将一个字符串分成两部分,首字母 剩下的
字符串大小写 toUpperCase() toLowerCase()
字符串截取 slice substr substring
console.log( String.prototype );
function String(){ }
举例原理:如果是全大写是这么写的
String.prototype.toUpperCase = function(){ }
如果我们想添加拓展 一个功能可以直接这么添加
String.prototype.daxie = function(){ //首字母大写 // console.log(this); // this 代表字符串本身 //截取首字母 this.slice(0, 1) 截取其他的 this.slice(1) //this.slice(0, 1).toUpperCase() this.slice(1).toLowerCase() //返回结果 return this.slice(0, 1).toUpperCase() + this.slice(1).toLowerCase(); }
console.log( 'hello'.daxie() ); console.log( 'wOrLd'.daxie() );
// 如果给String扩展,所有的字符串都可以调用
// 如果给Array扩展,所有的数组都可以调用
// 如果给Object扩展,所有的对象都可以调用
这种技术被称为猴子补丁,并且会破坏封装。尽管一些流行的框架(如 Prototype.js)在使用该技术,但仍然没有足够好的理由使用附加的非标准方法来混入内置原型。
本站内容均为小米原创,转载请注明出处:小米技术社区>> 为内置对象扩展方法(猴子补丁)