仿String()构造器函数 【总结】
需求
实现以下方法:

控制台结果:

需求分析:
首先确定new调用的this和什么对象绑定,如果跟默认返回的对象绑定肯定做不到 [ ] 这样的访问,所以要在构造器内部返回一个包装过的数组
1.length,既然前提是没有String()构造器函数,那就不能用字符串对象的length方法,所以首先要将接收的字符串包装成数组。虽说不能用字符串对象的方法,但这里还是用到了 ES5的 [ ] 中括号访问法,为了将字符串中的每一个字符做成数组中的每一项,这样length就可以直接使用数组本身有的。
2. [ ] 中括号访问法,直接用数组的
3.toString() 方法内部实现就是调用数组的join();方法
4.valueOf() 方法同上
5.charAt() 方法,规定如果参数是数字或是字符串,只要它是由纯数字组成的就应该返回正确的结果,如果包含非数字的字符就返回第一个字符。实现方式就是简单判断传入的参 数,然后像使用数组一样使用上面包装过的字符串数组来返回正确的值。
6.concat() 方法,在内部调用toValue()方法,加上传进来的参数,然后返回出去。
7.slice() 方法,要求返回第一个参数的字符和第二个参数-1的之间的字符;如果是负数就与将参数与字符串长度相加。
8.split() 方法,将传入的参数作为分隔符,将字符串分割成数组。
实现思路:
第一步要确认this与什么对象绑定,也就是构造器函数返回什么对象,这一点很重要,不知道是不是属于OOP的风格。
难点:
split怎么做,如果只是匹配单个字符还容易,多字符匹配做起来显得有点吃力。
难点解决方案:
第一步:检测字符数组的每一项,如果与期望字符串的第一个匹配就进入第二步
第二步:用循环匹配后面的字符,如果有一个不相等就break出来
第三步:匹配判断结束后( 不管是break过还是没break过都要判断 ),如果匹配结束后的循环索引等于期望字符串的长度,说明中途没有被中断过
第四步:记录下这个没有被中断过的位置,然后将它对应的起始位置,也就是 i 保存到一个数组里,再将这个数组保存到更大的数组里。
涉及的新知识:
OOP
优化方向:
不知道可不可以用正则去优化。
备注:
OOP风格的js可能需要先想好this与什么对象绑定,这个对象就像是身体,要先确定是什么样的身体才能根据它衍生出不同的功能。
仿String()构造器函数 【总结】的更多相关文章
- 在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性:
在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性: var s = new MyString("hello"); s ...
- (练习题)利用构造器函数实现三个小实例——不使用String()与Array()构造器和Math对象,不使用内建的方法的方法和属性。
1)在String()构造器不存在的情况下自定义一个myString()构造器函数.由于String()不存在,因此您在写构造器函数时不能使用任何属于内建String对象的方法和属性.并让你所创建的对 ...
- js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法:
js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法: var s = new MyString('hello'); s.length; s[0]; // " ...
- javascript对象初探(一)--- 构造器函数
我们可以通过构造器函数(简称构造函数)来创建对象: function Her(){ this.child = 'Jon'; } 为了使用该函数来创建对象,我们需要使用new操作符,例如: var sh ...
- java String.split()函数的用法分析
java String.split()函数的用法分析 栏目:Java基础 作者:admin 日期:2015-04-06 评论:0 点击: 3,195 次 在java.lang包中有String.spl ...
- string.capwords()函数
string.capwords()函数 string.capwords()函数,有需要的朋友可以参考下. 代码 : import syssys.path.append("C:/Python2 ...
- js--使用构造器函数来新建对象及操作
通过new操作符来调用函数,来达到访问对象this值得目的,构造器将其创建的对象返回给我们. 直接上代码 //创建构造器函数 function Gadget(name, color){ this.na ...
- public static void main(String[] args){}函数诠释
public static void main(String[] args){}函数诠释 主函数的一般写法如下: public static void main(String[] args){-} 下 ...
- Js对象转String的函数 和 JSON转String
js对象转string的函数 function obj2str(o){ var r = []; if(typeof o =="string") return "" ...
随机推荐
- CURL (CommandLine Uniform Resource Locator) 简易教程!
1 http://curl.haxx.se/ http://curl.haxx.se/docs/httpscripting.html curl is an open source command li ...
- 1 line of CSS Layouts
1 line of CSS Layouts 10 modern layouts in 1 line of CSS 1. 绝对居中布局 <div class="container&quo ...
- Linux bash shell All In One
Linux bash shell All In One Linux https://tinylab.gitbooks.io/shellbook/content/zh/chapters/01-chapt ...
- Expose Loader & shit jquery
Expose Loader webpack https://github.com/xgqfrms/FEIQA/issues/31#issuecomment-418255126 require(&quo ...
- The State of JavaScript 2019
The State of JavaScript 2019 https://stateofjs.com/ https://survey.stateofjs.com/ https://2018.state ...
- WPF权限控制——【3】数据库、自定义弹窗、表单验证
你相信"物竞天择,适者生存"这样的学说吗?但是我们今天却在提倡"尊老爱幼,救死扶伤",帮助并救护弱势群体:第二次世界大战期间,希特勒认为自己是优等民族,劣势民族 ...
- int和Integer的比较详解
说明: int为基本类型,Integer为包装类型: 装箱: 基本类型---> 包装类型 int ---> Integer 底层源码: .intValue() 拆箱: 包装类型---> ...
- SPEC-RFC3261总述
最近学习VoLTE(Voice Vver LTE)相关知识,而学习VoLTE必须要学相关的协议,最基础的就是RFC3261,RFC3261的全称是:SIP: Session Initiation Pr ...
- Java开发的得力助手---Guava
导语 guava是google出品的java类库,被google广泛用于内部项目,该类库经过google大牛们的千锤百炼,以优雅的设计在java世界流行.版本迭代至今,很多思想甚至被JDK标准库借鉴, ...
- SpringBoot2.1中添加过滤器配置
1:构造一个实现 Filter 接口的过滤器,并在类上添加@component注释: notice1:若不添加,则需在spring中注入该bean,不然会报错. package com.dev.fil ...