JavaScript中String.prototype用法实例


Posted in Javascript onMay 20, 2015

本文实例讲述了JavaScript中String.prototype用法。分享给大家供大家参考。具体如下:

// 返回字符的长度,一个中文算2个
String.prototype.ChineseLength=function()
{ 
  return this.replace(/[^\x00-\xff]/g,"**").length;
}
// 判断字符串是否以指定的字符串结束
String.prototype.EndsWith = function(str) 
{
  return this.substr(this.length - str.length) == str;
}
// 去掉字符左端的的空白字符
String.prototype.LeftTrim = function()
{
  return this.replace(/(^[\\s]*)/g, "");
}
// 去掉字符右端的空白字符
String.prototype.RightTrim = function()
{
  return this.replace(/([\\s]*$)/g, "");
}
// 判断字符串是否以指定的字符串开始
String.prototype.StartsWith = function(str) 
{
  return this.substr(0, str.length) == str;
}
// 去掉字符两端的空白字符
String.prototype.Trim = function()
{
  return this.replace(/(^\s*)|(\s*$)/g, "");
}

这就是我们经常看到的为内部对象, 如 String, Math 等再添加其它属性和方法的技巧. 对于任何的内部对象和自定义对象, 你都也可以通过 prototype 来重载其下的属性和方法. 那么在调用执行时, 它将调用你所定义的方法和属性. 下面是示例:

// 为内部 String 对象添加方法
String.prototype.myMethod = function(){
 return "my define method";
}
// 为内部 String 对象重载方法
String.prototype.toString = function(){
 return "my define toString method";
}
var myObj = new String("foo");
alert(myObj.myMethod());
alert(myObj);
alert("foo".toString());

另外需要注意的是, 所有 JavaScript 内部对的 prototype 属性都是只读的. 你可以像上面那样为内部对象的原型添加或重载属性和方法,但不能更改该内部对象的 prototype 原型. 然而, 自定义对象可以被赋给新的原型. 也就是说, 像下面这样做是没有意思的.

function Employee() {
 this.dept = "HR";
 this.manager = "John Johnson";
}
String.prototype = new Employee;
var myString = new String("foo");

上面的程序在运行之后不会报错, 但显然, 如果你调用 myString.dept 将会得到一个非定义的值.

另外, 一个经常使用的是 prototype 下的 isPrototypeOf() 方法, 它主要用来判断指定对象是否存在于另一个对象的原型链中. 语法如下:

object1.prototype.isPrototypeOf(0bject2);

上面的格式是用来判断 Object2 是否出现 Object1 的原型链中. 示例如下:

function Person() {
 this.name = "Rob Roberson";
 this.age = 31;
}
function Employee() {
 this.dept = "HR";
 this.manager = "John Johnson";
}
Employee.prototype = new Person();
var Ken = new Employee();

当执行 Employee.prototype.isPrototypeOf(Ken), Person.prototype.isPrototypeOf(Ken) 和 Object.prototype.isPrototypeOf(Ken) 时, 结果都会返回 true.

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
使用jQuery+HttpHandler+xml模拟一个三级联动的例子
Aug 09 Javascript
js 处理数组重复元素示例代码
Dec 27 Javascript
javascript函数特点实例分析
May 14 Javascript
JS实现横向拉伸动感伸缩菜单效果代码
Sep 04 Javascript
php利用curl获取远程图片实现方法
Oct 26 Javascript
jquery.cookie实现的客户端购物车操作实例
Dec 24 Javascript
Node.js + Redis Sorted Set实现任务队列
Sep 19 Javascript
详解vue过滤器在v2.0版本用法
Jun 01 Javascript
一篇文章让你彻底弄懂JS的事件冒泡和事件捕获
Aug 14 Javascript
React实践之Tree组件的使用方法
Sep 30 Javascript
JavaScript中正则表达式使数字、中文或指定字符高亮显示
Oct 31 Javascript
解决vue的 v-for 循环中图片加载路径问题
Sep 03 Javascript
实现无刷新联动例子汇总
May 20 #Javascript
javascript中CheckBox全选终极方案
May 20 #Javascript
javascript消除window.close()的提示窗口
May 20 #Javascript
在JS方法中返回多个值的方法汇总
May 20 #Javascript
AspNet中使用JQuery上传插件Uploadify详解
May 20 #Javascript
AspNet中使用JQuery boxy插件的确认框
May 20 #Javascript
JQuery boxy插件在IE中边角图片不显示问题的解决
May 20 #Javascript
You might like
ThinkPHP中的关联模型注意点
2014/06/16 PHP
php命令行用法入门实例教程
2014/10/27 PHP
php中使用base HTTP验证的方法
2015/04/20 PHP
PHP设计模式之工厂模式实例总结
2017/09/01 PHP
php获取微信共享收货地址的方法
2017/12/21 PHP
使用jquery实现div的tab切换实例代码
2013/05/27 Javascript
获取当前点击按钮的id用this.id实现
2014/03/17 Javascript
深入探讨JavaScript、JQuery屏蔽网页鼠标右键菜单及禁止选择复制
2014/06/10 Javascript
用Node.js通过sitemap.xml批量抓取美女图片
2015/05/28 Javascript
javascript函数中的3个高级技巧
2016/09/22 Javascript
javascript 利用arguments实现可变长参数
2016/11/21 Javascript
jquery封装插件时匿名函数形参和实参的写法解释
2017/02/14 Javascript
JS实现闭包中的沙箱模式示例
2017/09/07 Javascript
小程序实现展开/收起的效果示例
2018/09/22 Javascript
vue+AI智能机器人回复功能实现
2020/07/16 Javascript
[05:20]2018DOTA2亚洲邀请赛主赛事第三日战况回顾 LGD率先挺进胜者组决赛
2018/04/06 DOTA
[09:47]2018DOTA2亚洲邀请赛4.5SOLO赛 No[o]ne vs Sumail
2018/04/06 DOTA
Python配置mysql的教程(推荐)
2017/10/13 Python
python print 按逗号或空格分隔的方法
2018/05/02 Python
Python数据分析matplotlib设置多个子图的间距方法
2018/08/03 Python
Python中的函数式编程:不可变的数据结构
2018/10/08 Python
Python命名空间的本质和加载顺序
2018/12/17 Python
详解PANDAS 数据合并与重塑(join/merge篇)
2019/07/09 Python
django中的图片验证码功能
2019/09/18 Python
Pytorch转onnx、torchscript方式
2020/05/25 Python
python3的pip路径在哪
2020/06/23 Python
面向中国市场的在线海淘美妆零售网站:Beauty House美丽屋
2021/03/02 全球购物
某公司Java工程师面试题笔试题
2016/03/27 面试题
电话销售经理岗位职责
2013/12/07 职场文书
单位租车协议书
2015/01/29 职场文书
开会通知短信大全
2015/04/20 职场文书
长江七号观后感
2015/06/11 职场文书
重阳节简报
2015/07/20 职场文书
求职信:会计求职的写作技巧
2019/04/24 职场文书
如何书写你的职业生涯规划书?
2019/06/27 职场文书
Ruby处理CSV数据方法详解
2022/04/18 Ruby