收集的一些Array及String原型对象的扩展实现代码


Posted in Javascript onDecember 05, 2010

从无忧脚本收集过来的,有些的确还不错,比较实用,值得收藏一下。
扩展Array的原型对象的方法

// 删除数组中数据 
Array.prototype.del = function(n) 
{ 
if (n<0) return this; 
return this.slice(0,n).concat(this.slice(n+1,this.length)); 
} 
// 数组洗牌 
Array.prototype.random = function() 
{ 
var nr=[], me=this, t; 
while(me.length>0) 
{ 
nr[nr.length] = me[t = Math.floor(Math.random() * me.length)]; 
me = me.del(t); 
} 
return nr; 
} 
// 数字数组排序 
Array.prototype.sortNum = function(f) 
{ 
if (!f) f=0; 
if (f==1) return this.sort(function(a,b){return b-a;}); 
return this.sort(function(a,b){return a-b;}); 
} 
// 获得数字数组的最大项 
Array.prototype.getMax = function() 
{ 
return this.sortNum(1)[0]; 
} 
// 获得数字数组的最小项 
Array.prototype.getMin = function() 
{ 
return this.sortNum(0)[0]; 
} 
// 数组第一次出现指定元素值的位置 
Array.prototype.indexOf = function(o) 
{ 
for (var i=0; i<this.length; i++) if (this[i]==o) return i; 
return -1; 
} 
// 移除数组中重复的项 
Array.prototype.removeRepeat=function() 
{ 
this.sort(); 
var rs = []; 
var cr = false; 
for (var i=0; i<this.length; i++) 
{ 
if (!cr) cr = this[i]; 
else if (cr==this[i]) rs[rs.length] = i; 
else cr = this[i]; 
} 
var re = this; 
for (var i=rs.length-1; i>=0; i--) re = re.del(rs[i]); 
return re; 
}

例子:
var arr=["ni","wo","ta"];
删除数组中的“wo”
var newArr=arr.del(1);
返回数组中“me”第一次出现的位置,若没有就返回-1
var strPos=arr.indexOf("me");

扩展String的原型对象的方法

//获取字符数组 
String.prototype.ToCharArray=function() 
{ 
return this.split(""); 
} 
//获取N个相同的字符串 
String.prototype.Repeat=function(num) 
{ 
var tmpArr=[]; 
for(var i=0;i<num;i++) tmpArr.push(this); 
return tmpArr.join(""); 
} 
//逆序 
String.prototype.Reverse=function() 
{ 
return this.split("").reverse().join(""); 
} 
//测试是否是数字 
String.prototype.IsNumeric=function() 
{ 
var tmpFloat=parseFloat(this); 
if(isNaN(tmpFloat)) return false; 
var tmpLen=this.length-tmpFloat.toString().length; 
return tmpFloat+"0".Repeat(tmpLen)==this; 
} 
//测试是否是整数 
String.prototype.IsInt=function() 
{ 
if(this=="NaN") return false; 
return this==parseInt(this).toString(); 
} 
// 合并多个空白为一个空白 
String.prototype.resetBlank = function() 
{ 
return this.replace(/s+/g," "); 
} 
// 除去左边空白 
String.prototype.LTrim = function() 
{ 
return this.replace(/^s+/g,""); 
} 
// 除去右边空白 
String.prototype.RTrim = function() 
{ 
return this.replace(/s+$/g,""); 
} 
// 除去两边空白 
String.prototype.trim = function() 
{ 
return this.replace(/(^s+)|(s+$)/g,""); 
} 
// 保留数字 
String.prototype.getNum = function() 
{ 
return this.replace(/[^d]/g,""); 
} 
// 保留字母 
String.prototype.getEn = function() 
{ 
return this.replace(/[^A-Za-z]/g,""); 
} 
// 保留中文 
String.prototype.getCn = function() 
{ 
return this.replace(/[^u4e00-u9fa5uf900-ufa2d]/g,""); 
} 
// 得到字节长度 
String.prototype.getRealLength = function() 
{ 
return this.replace(/[^x00-xff]/g,"--").length; 
} 
// 从左截取指定长度的字串 
String.prototype.left = function(n) 
{ 
return this.slice(0,n); 
} 
// 从右截取指定长度的字串 
String.prototype.right = function(n) 
{ 
return this.slice(this.length-n); 
} 
// HTML编码 
String.prototype.HTMLEncode = function() 
{ 
var re = this; 
var q1 = [/x26/g,/x3C/g,/x3E/g,/x20/g]; 
var q2 = ["&","<",">"," "]; 
for(var i=0;i<q1.length;i++) 
re = re.replace(q1[i],q2[i]); 
return re; 
} 
// Unicode转化 
String.prototype.ascW = function() 
{ 
var strText = ""; 
for (var i=0; i<this.length; i++) strText += "&#" + this.charCodeAt(i) + ";"; 
return strText; 
}
Javascript 相关文章推荐
js弹出的对话窗口永远保持居中显示
Dec 15 Javascript
THREE.JS入门教程(2)着色器-上
Jan 24 Javascript
利用CSS、JavaScript及Ajax实现高效的图片预加载
Oct 16 Javascript
一个简单的实现下拉框多选的插件可移植性比较好
May 05 Javascript
详解Javascript 装载和执行
Nov 17 Javascript
node.js中的console.log方法使用说明
Dec 09 Javascript
JQUERY表单暂存功能插件分享
Feb 23 Javascript
AngularJS基础 ng-hide 指令用法及示例代码
Aug 01 Javascript
Google 地图API Map()构造器详解
Aug 06 Javascript
JavaScript注入漏洞的原理及防范(详解)
Dec 04 Javascript
js字符串类型String常用操作实例总结
Jul 05 Javascript
微信小程序基于高德地图查找位置并显示文字
Oct 30 Javascript
script标签的 charset 属性使用说明
Dec 04 #Javascript
本地对象Array的原型扩展实现代码
Dec 04 #Javascript
悄悄用脚本检查你访问过哪些网站的代码
Dec 04 #Javascript
jQuery)扩展jQuery系列之一 模拟alert,confirm(一)
Dec 04 #Javascript
高效的表格行背景隔行变色及选定高亮的JS代码
Dec 04 #Javascript
javascript innerHTML使用分析
Dec 03 #Javascript
统计出现最多的字符次数的js代码
Dec 03 #Javascript
You might like
长波知识介绍
2021/03/01 无线电
用ADODB来让PHP操作ACCESS数据库的方法
2006/12/31 PHP
PDO::setAttribute讲解
2019/01/29 PHP
js函数的引用, 关于内存的开销
2012/09/17 Javascript
jquery学习总结(超级详细)
2014/09/04 Javascript
小结Node.js中非阻塞IO和事件循环
2014/09/18 Javascript
jQuery手机拨号界面特效代码分享
2015/08/27 Javascript
Jquery ajax请求导出Excel表格的实现代码
2016/06/08 Javascript
jquery制做精致的倒计时特效
2016/06/13 Javascript
jQuery使用deferreds串行多个ajax请求
2016/08/22 Javascript
JavaScript实现垂直向上无缝滚动特效代码
2016/11/23 Javascript
微信小程序tabbar不显示解决办法
2017/06/08 Javascript
jQuery实现菜单栏导航效果
2017/08/15 jQuery
webpack打包js文件及部署的实现方法
2017/12/18 Javascript
vue.js添加一些触摸事件以及安装fastclick的实例
2018/08/28 Javascript
Puppet的一些技巧
2018/09/17 Javascript
详解mpvue scroll-view自动回弹bug解决方案
2018/10/01 Javascript
如何为vue的项目添加单元测试
2018/12/19 Javascript
详解vue-router 动态路由下子页面多页共活的解决方案
2019/12/22 Javascript
python实现的简单猜数字游戏
2015/04/04 Python
python3+PyQt5实现支持多线程的页面索引器应用程序
2018/04/20 Python
Python 批量合并多个txt文件的实例讲解
2018/05/08 Python
Python字典创建 遍历 添加等实用基础操作技巧
2018/09/13 Python
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
Python3实现的判断环形链表算法示例
2019/03/07 Python
python 实现单例模式的5种方法
2020/09/23 Python
python 实现数据库中数据添加、查询与更新的示例代码
2020/12/07 Python
python中xlutils库用法浅析
2020/12/29 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
Claire’s法国:时尚配饰、美容、珠宝、头发
2021/01/16 全球购物
C有"按引用传递"吗
2016/09/06 面试题
告诉你怎样写创业计划书
2014/01/27 职场文书
高中毕业生登记表自我鉴定范文
2014/03/18 职场文书
模特大赛策划方案
2014/05/28 职场文书
小学生植树节活动总结
2014/07/04 职场文书
Spring Security使用单点登录的权限功能
2022/04/03 Java/Android