js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法:

var s = new MyString('hello');
s.length; //
s[0]; // "h"
s.toString(); // "hello"
s.valueOf(); // "hello"
s.charAt(1); // "e"
s.charAt('2'); // "l"
s.charAt('e'); // "h"
s.concat(' world!'); // "hello world!"
s.slice(1, 3); // "el"
s.slice(0, -1); // "hell"
s.split('e'); // ["h", "llo"]
s.split('l'); // ["h", "", "o"]
s.split(); // ["hello"]
s.reverse(); // "olleh"
function MyString(str) {
var str = str.toString();
var arr = [];
for (var i in str) {
this[i] = arr[i] = str[i];
}
this.length = arr.length;
this['[[PrimitiveValue]]'] = str;
}
MyString.prototype.toString = function () {
return this['[[PrimitiveValue]]']+'';
}
MyString.prototype.valueOf = function () {
return this['[[PrimitiveValue]]'];
}
MyString.prototype.charAt = function (pos) {
var pos = pos*1 || 0;
return this[pos] || '';
}
MyString.prototype.concat = function (strings) {
return this.toString()+strings;
}
MyString.prototype.slice = function (start,end) {
var start = start>=0?start : this.length+start || 0; //-1
var end = end >=0?end : this.length+end || 0; //-1
start = start <= this.length ? start:this.length;
end = end <= this.length ? end:this.length;
var str = '';
for (var i = start; i<end; i++) {
str+=this[i];
}
return str;
}
MyString.prototype.split = function (separator) {
var arr = [];
var index=0;
for (var i=0; i<this.length; i++){
if(this[i]==separator) {
arr[arr.length] = this.slice(index,i);
index = i+1;
}
}
arr[arr.length] = this.slice(index,i);
return arr;
}
// for循环版
MyString.prototype.reverse = function () {
var str = '';
for (var i = this.length-1; i>-1; i--) {
str += this[i];
}
return str;
}
//借助数组的reverse()方法
MyString.prototype.reverse = function () {
var arr = [];
for (var i = 0; i<this.length; i++) {
arr[arr.length] = this[i];
}
return arr.reverse().join('');
}

亲,记得点赞哦!

js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法:的更多相关文章

  1. python进阶之函数和类内建魔法属性

    前言 关于对象的魔法方法我们已经讲得太多,但是对于类或函数内建的魔法属性和功能我们涉及较少,下面系统了解一下类和函数的内建属性. 查看内建属性 class Person(object): pass d ...

  2. 在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性:

    在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性: var s = new MyString("hello"); s ...

  3. 深入理解javascript函数系列第三篇——属性和方法

    × 目录 [1]属性 [2]方法 前面的话 函数是javascript中的特殊的对象,可以拥有属性和方法,就像普通的对象拥有属性和方法一样.甚至可以用Function()构造函数来创建新的函数对象.本 ...

  4. [.net 面向对象编程基础] (10) 类的成员(字段、属性、方法)

    [.net 面向对象编程基础] (10) 类的成员(字段.属性.方法) 前面定义的Person的类,里面的成员包括:字段.属性.方法.事件等,此外,前面说的嵌套类也是类的成员. a.类的成员为分:静态 ...

  5. python inspect 模块 和 types 模块 判断是否是方法,模块,函数等内置特殊属性

    python inspect 模块 和 types 模块 判断是否是方法,模块,函数等内置特殊属性 inspect import inspect def fun(): pass inspect.ism ...

  6. Js基础知识7-JavaScript所有内置对象属性和方法汇总

    对象什么的,程序员可是有很多呢... JS三大对象 对象,是任何一个开发者都无法绕开和逃避的话题,她似乎有些深不可测,但如此伟大和巧妙的存在,一定值得你去摸索.发现.征服. 我们都知道,JavaScr ...

  7. [js高手之路]原型对象(prototype)与原型链相关属性与方法详解

    一,instanceof: instanceof检测左侧的__proto__原型链上,是否存在右侧的prototype原型. 我在之前的两篇文章 [js高手之路]构造函数的基本特性与优缺点 [js高手 ...

  8. js 内置对象属性及方法

    1.Date 属性(1): constructor      所建立对象的函数参考 prototype       能够为对象加入的属性和方法 方法(43): getDay()        返回一周 ...

  9. js 面向对象中,定义一个函数的过程

    定义一个函数做的两件事:1: 实例化一个Function对象:2: 实例化一个Object对象,并给该函数扩展prototype属性指向这个构造函数 大致过程如图所示: 每一种引用类型(函数,对象,数 ...

随机推荐

  1. loj题目总览

    --DavidJing提供技术支持 现将今年7月份之前必须刷完的题目列举 完成度[23/34] [178/250] 第 1 章 贪心算法 √ [11/11] #10000 「一本通 1.1 例 1」活 ...

  2. springboot 多模块打war 部署

    先展示一下自己项目结构 一共有5个模块 依赖关系:下面的模块依赖上面所有的模块 其中 rongke-web是我要部署的模块 最终要打war进行部署,其他模块均打jar 被rongke-web引用. 开 ...

  3. git在项目中的实际运用

    项目中只运用git版本管理的情况下: 1.创建分支命令: git branch (branchname) 切换分支命令: git checkout (branchname) 当你切换分支的时候,Git ...

  4. 非递归并查集——zoj4109

    卡常卡的我难受 非递归并查集好像写起来常数小一点 int F[maxn]; int Find(int x){ int r = x; while (F[r] != r)r = F[r]; int i = ...

  5. windows安装node和yarn

    Ubuntu子系统安装和删除yarn 在 Debian 或 Ubuntu 上,需要用 Debian 包仓库来安装 Yarn. 首先需要配置仓库: curl -sS https://dl.yarnpkg ...

  6. mybatis和hibernate中的懒加载

    概念:所谓懒加载就是延时加载,延迟加载.什么时候用懒加载呢,我只能回答要用懒加载的时候就用懒加载.至于为什么要用懒加载呢,就是当我们要访问的数据量过大时,明显用缓存不太合适,因为内存容量有限 ,为了减 ...

  7. pojo,javabean与entitybean

    pojo:朴实无华的实体类 javabean:遵守某些规范的可重用的实体类 entitybean:与数据库中的数据记录对应的类 这个链接说的很明白!https://blog.csdn.net/chen ...

  8. ISP PIPLINE (十一) color correction

    什么是color correction? 为什么要进行color correction? 转换后的色彩饱和度更加明显,更加符合人眼感官. 如何进行color correction? 下图是步骤: 第一 ...

  9. js基础知识易错点(一)

    最近替另一个项目招人,要求基础知识好,随便问了一些基础题,发现了一些易错的点,总结一下. 1.判断一个空数组 var arr = []; 1)JSON.stringify(arr) == " ...

  10. url.cn短网址批量缩短开发接口

    https://www.showapi.com/api/view/1728 //md5签名方式--非简单签名 <?php header("Content-Type:text/html; ...