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. 帆软报表(finereport)使用row_number ()进行组内排序

    ROW_NUMBER()函数将针对SELECT语句返回的每一行,从1开始编号,赋予其连续的编号.在查询时应用了一个排序标准后,只有通过编号才能够保证其顺序是一致的,当使用ROW_NUMBER函数时,也 ...

  2. 从头开始学Maven【依赖范围】

    例如 <dependencies> <dependency> <groupId></groupId> <artifactId></ar ...

  3. JAVA This的简单运用

    package Code426;/*当方法的局部变量和类的成员变量重名时,根据“就近原则”,优先使用局部变量如果需要访问本类当中的成员变量,需要使用 this.成员变量 通过谁调用的方法,谁就是thi ...

  4. zabbix_agentd客户端安装与配置(windows操作系统)

    zabbix_agentd客户端安装与配置(windows操作系统)   **********  客户端操作   **********  标注:监控zabbix_agentd客户端安装对象是win s ...

  5. struts2-剩余

    一.说明 类型转换.输入验证(前台和后台)(validate().validateXXX().xml) 标签.上传下载.i18n(国际化).ognl(#reqeust.name) 注解方式.log4j ...

  6. JS中函数常见的表现形式以及立即执行函数

    函数常见的几种表现形式: 1.一般形式(函数声明): 会进行函数的预解释,函数会进行声明和定义,在函数体前面或则后面都可以进行调用. 2.函数表达式(匿名函数): 会进行函数的预解析,函数会进行声明但 ...

  7. 末学者笔记--shell编程上 2 玄

    Shell编程-变量及表达运算 [内容简列] 1. shell变量简介 2. 定义变量 3. 使用变量 4. 修改变量的值 5. 单引号和双引号的区别 6. 将命令的结果赋值给变量 7. 删除变量 8 ...

  8. linux常用命令及使用技巧(一)

    shell命令格式:command [options][arguments] shell的通配符 *匹配任意一个或多个字符 ?匹配任意单一字符 []匹配任何包含在方括号内的单字符 shell的重定向: ...

  9. 使用IIS应用程序初始化来保持ASP.NET应用程序的活动

    https://weblog.west-wind.com/posts/2013/Oct/02/Use-IIS-Application-Initialization-for-keeping-ASPNET ...

  10. python接口自动化1

    组织架构: 包括配置文件,反射.文件路径.Excel操作.测试报告生成 case.config [MODE] file_name=case_data.xlsx mode={"register ...