js字符串函數(shù)

W3C JavaScript String 對象
js字符串函數(shù)

JS自帶函數(shù)

concat 將兩個(gè)或多個(gè)字符的文本組合起來,返回一個(gè)新的字符串泣棋。
var a = "hello";
var b = ",world";
var c = a.concat(b);
alert(c);
//c = "hello,world"
indexOf 返回字符串中一個(gè)子串第一處出現(xiàn)的索引(從左到右搜索)愚隧。如果沒有匹配項(xiàng),返回 -1,開頭返回0,匹配到返回任意正數(shù) 撼嗓。
var index1 = a.indexOf("l");
//index1 = 2
var index2 = a.indexOf("l",3);
//index2 = 3
charAt 返回指定位置的字符。
var get_char = a.charAt(0);
//get_char = "h"
lastIndexOf

返回字符串中一個(gè)子串最后一處出現(xiàn)的索引(從右到左搜索)欢唾,如果沒有匹配項(xiàng)且警,返回 -1 。

var index1 = lastIndexOf('l');
//index1 = 3
var index2 = lastIndexOf('l',2)
//index2 = 2
match 檢查一個(gè)字符串匹配一個(gè)正則表達(dá)式內(nèi)容礁遣,如果么有匹配返回 null斑芜。
var re = new RegExp(/^\w+$/);
var is_alpha1 = a.match(re);
//is_alpha1 = "hello"
var is_alpha2 = b.match(re);
//is_alpha2 = null
substring

返回字符串的一個(gè)子串,傳入?yún)?shù)是起始位置和結(jié)束位置祟霍。

var sub_string1 = a.substring(1);
//sub_string1 = "ello"
var sub_string2 = a.substring(1,4);
//sub_string2 = "ell"
substr 返回字符串的一個(gè)子串押搪,傳入?yún)?shù)是起始位置和長度
var sub_string1 = a.substr(1);
//sub_string1 = "ello"
var sub_string2 = a.substr(1,4);
//sub_string2 = "ello"
replace 用來查找匹配一個(gè)正則表達(dá)式的字符串,然后使用新字符串代替匹配的字符串浅碾。
var result1 = a.replace(re,"Hello");
//result1 = "Hello"
var result2 = b.replace(re,"Hello");
//result2 = ",world"
search 執(zhí)行一個(gè)正則表達(dá)式匹配查找大州。如果查找成功,返回字符串中匹配的索引值垂谢。否則返回 -1 厦画。
var index1 = a.search(re);
//index1 = 0
var index2 = b.search(re);
//index2 = -1
slice 提取字符串的一部分,并返回一個(gè)新字符串(與 substring 相同)滥朱。
var sub_string1 = a.slice(1);
//sub_string1 = "ello"
var sub_string2 = a.slice(1,4);
//sub_string2 = "ell"
split 通過將字符串劃分成子串根暑,將一個(gè)字符串做成一個(gè)字符串?dāng)?shù)組。
var arr1 = a.split("");
//arr1 = [h,e,l,l,o]
length 返回字符串的長度徙邻,所謂字符串的長度是指其包含的字符的個(gè)數(shù)排嫌。
var len = a.length();
//len = 5
toLowerCase 將整個(gè)字符串轉(zhuǎn)成小寫字母。
var lower_string = a.toLowerCase();
//lower_string = "hello"
toUpperCase 將整個(gè)字符串轉(zhuǎn)成大寫字母缰犁。
var upper_string = a.toUpperCase();
//upper_string = "HELLO"

字符串函數(shù)擴(kuò)充

去除左邊的空格
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.Left = function(len)
{

if(isNaN(len)||len==null)
{
len = this.length;
}
else
{
if(parseInt(len)<0||parseInt(len)>this.length)
{
len = this.length;
}
}

return this.substr(0,len);
}
得到右邊的字符串
String.prototype.Right = function(len)
{

if(isNaN(len)||len==null)
{
len = this.length;
}
else
{
if(parseInt(len)<0||parseInt(len)>this.length)
{
len = this.length;
}
}

return this.substring(this.length-len,this.length);
}
得到中間的字符串,注意從0開始
String.prototype.Mid = function(start,len)
{
return this.substr(start,len);
}
在字符串里查找另一字符串:位置從0開始
String.prototype.InStr = function(str)
{

if(str==null)
{
str = "";
}

return this.indexOf(str);
}

在字符串里反向查找另一字符串:位置0開始
String.prototype.InStrRev = function(str)
{

if(str==null)
{
str = "";
}

return this.lastIndexOf(str);
}
計(jì)算字符串打印長度
String.prototype.LengthW = function()
{
return this.replace(/[^\x00-\xff]/g,"**").length;
}
是否是正確的IP地址
String.prototype.isIP = function()
{

var reSpaceCheck = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/;

if (reSpaceCheck.test(this))
{
this.match(reSpaceCheck);
if (RegExp.$1 <= 255 && RegExp.$1 >= 0
&& RegExp.$2 <= 255 && RegExp.$2 >= 0
&& RegExp.$3 <= 255 && RegExp.$3 >= 0
&& RegExp.$4 <= 255 && RegExp.$4 >= 0)
{
return true;    
}
else
{
return false;
}
}
else
{
return false;
}

}
是否是正確的長日期
String.prototype.isLongDate = function()
{
var r = this.replace(/(^\s*)|(\s*$)/g, "").match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/);
if(r==null)
{
return false;
}
var d = new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);

}

是否是正確的短日期

String.prototype.isShortDate = function()
{
var r = this.replace(/(^\s*)|(\s*$)/g, "").match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if(r==null)
{
return false;
}
var d = new Date(r[1], r[3]-1, r[4]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);
}
是否是正確的日期
String.prototype.isDate = function()
{
return this.isLongDate()||this.isShortDate();
}
是否是手機(jī)
String.prototype.isMobile = function()
{
return /^0{0,1}13[0-9]{9}$/.test(this);
}
/是否是郵件
String.prototype.isEmail = function()
{
return /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/.test(this);
}
是否是郵編(中國)
String.prototype.isZipCode = function()
{
return /^[\\d]{6}$/.test(this);
}
是否是有漢字
String.prototype.existChinese = function()
{
//[\u4E00-\u9FA5]為漢字﹐[\uFE30-\uFFA0]為全角符號
return /^[\x00-\xff]*$/.test(this);
}
是否是合法的文件名/目錄名
String.prototype.isFileName = function()
{
return !/[\\\/\*\?\|:"<>]/g.test(this);
}
是否是有效鏈接
String.prototype.isUrl = function()
{
return /^http[s]?:\/\/([\w-]+\.)+[\w-]+([\w-./?%&=]*)?$/i.test(this);
}
是否是有效的身份證(中國)
String.prototype.isIDCard = function()
{
var iSum=0;
var info="";
var sId = this;

 var aCity={11:"北京",12:"天津",13:"河北",14:"山西",15:"內(nèi)蒙古",21:"遼寧",22:"吉林",23:"黑龍 江",31:"上海",32:"江蘇",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山東",41:"河南",42:"湖 北",43:"湖南",44:"廣東",45:"廣西",46:"海南",50:"重慶",51:"四川",52:"貴州",53:"云南",54:"西藏",61:"陜西",62:"甘肅",63:"青海",64:"寧夏",65:"新疆",71:"臺灣",81:"香港",82:"澳門",91:"國外"};

if(!/^\d{17}(\d|x)$/i.test(sId))
{
return false;
}
sId=sId.replace(/x$/i,"a");
//非法地區(qū)
if(aCity[parseInt(sId.substr(0,2))]==null)
{
return false;
}

var sBirthday=sId.substr(6,4)+"-"+Number(sId.substr(10,2))+"-"+Number(sId.substr(12,2));

var d=new Date(sBirthday.replace(/-/g,"/"))

//非法生日
if(sBirthday!=(d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate()))
{
return false;
}
for(var i = 17;i>=0;i--)
{
iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 - i),11);
}

if(iSum%11!=1)
{
return false;
}
return true;

}
是否是有效的電話號碼(中國)
String.prototype.isPhoneCall = function()
{
return /(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/.test(this);
}
是否是數(shù)字
String.prototype.isNumeric = function(flag)
{
//驗(yàn)證是否是數(shù)字
if(isNaN(this))
{

return false;
}

switch(flag)
{

case null:        //數(shù)字
case "":
return true;
case "+":        //正數(shù)
return                /(^\+?|^\d?)\d*\.?\d+$/.test(this);
case "-":        //負(fù)數(shù)
return                /^-\d*\.?\d+$/.test(this);
case "i":        //整數(shù)
return                /(^-?|^\+?|\d)\d+$/.test(this);
case "+i":        //正整數(shù)
return                /(^\d+$)|(^\+?\d+$)/.test(this);                       
case "-i":        //負(fù)整數(shù)
return                /^[-]\d+$/.test(this);
case "f":        //浮點(diǎn)數(shù)
return                /(^-?|^\+?|^\d?)\d*\.\d+$/.test(this);
case "+f":        //正浮點(diǎn)數(shù)
return                /(^\+?|^\d?)\d*\.\d+$/.test(this);                       
case "-f":        //負(fù)浮點(diǎn)數(shù)
return                /^[-]\d*\.\d$/.test(this);               
default:        //缺省
return true;                       
}
}
是否是顏色(#FFFFFF形式)
String.prototype.IsColor = function()
{
var temp        = this;
if (temp=="") return true;
if (temp.length!=7) return false;
return (temp.search(/\#[a-fA-F0-9]{6}/) != -1);
}
轉(zhuǎn)換成全角
String.prototype.toCase = function()
{
var tmp = "";
for(var i=0;i<this.length;i++)
{
if(this.charCodeAt(i)>0&&this.charCodeAt(i)<255)
{
tmp += String.fromCharCode(this.charCodeAt(i)+65248);
}
else
{
tmp += String.fromCharCode(this.charCodeAt(i));
}
}
return tmp
}
對字符串進(jìn)行Html編碼
String.prototype.toHtmlEncode = function()
{
var str = this;

str=str.replace(/&/g,"&");
str=str.replace(/</g,"<");
str=str.replace(/>/g,">");
str=str.replace(/\'/g,"'");
str=str.replace(/\"/g,""");
str=str.replace(/\n/g,"<br>");
str=str.replace(/\ /g," ");
str=str.replace(/\t/g,"    ");

return str;
}
轉(zhuǎn)換成日期
String.prototype.toDate = function()
{
try
{
return new Date(this.replace(/-/g, "\/"));
}
catch(e)
{
return null;
}
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末淳地,一起剝皮案震驚了整個(gè)濱河市怖糊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌颇象,老刑警劉巖伍伤,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異遣钳,居然都是意外死亡扰魂,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進(jìn)店門蕴茴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來劝评,“玉大人,你說我怎么就攤上這事倦淀〗螅” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵晃听,是天一觀的道長百侧。 經(jīng)常有香客問我,道長能扒,這世上最難降的妖魔是什么佣渴? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任绷耍,我火速辦了婚禮处渣,結(jié)果婚禮上间狂,老公的妹妹穿的比我還像新娘脐区。我一直安慰自己,他們只是感情好抑党,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布么介。 她就那樣靜靜地躺著谭跨,像睡著了一般鹃答。 火紅的嫁衣襯著肌膚如雪乎澄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天测摔,我揣著相機(jī)與錄音置济,去河邊找鬼。 笑死锋八,一個(gè)胖子當(dāng)著我的面吹牛浙于,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播挟纱,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼羞酗,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了紊服?” 一聲冷哼從身側(cè)響起檀轨,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤胸竞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后裤园,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體撤师,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡剂府,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年拧揽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片腺占。...
    茶點(diǎn)故事閱讀 38,039評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡淤袜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出衰伯,到底是詐尸還是另有隱情铡羡,我是刑警寧澤,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布意鲸,位于F島的核電站烦周,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏怎顾。R本人自食惡果不足惜读慎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望槐雾。 院中可真熱鬧夭委,春花似錦、人聲如沸募强。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽擎值。三九已至慌烧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鸠儿,已是汗流浹背屹蚊。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留捆交,地道東北人淑翼。 一個(gè)月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像品追,于是被迫代替她去往敵國和親玄括。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 第5章 引用類型(返回首頁) 本章內(nèi)容 使用對象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,212評論 0 4
  • 一肉瓦、字符串在C#中遭京,字符串是一系列不可修改的Unicode字符胃惜,創(chuàng)建字符串后,就不能修改它哪雕。要創(chuàng)建字符串船殉,最常用的...
    CarlDonitz閱讀 1,266評論 0 2
  • 本章內(nèi)容 使用對象 創(chuàng)建并操作數(shù)組 理解基本的 JavaScript 類型 使用基本類型和基本包裝類型 引用類型的...
    悶油瓶小張閱讀 676評論 0 0
  • 在挖掘分析的過程當(dāng)中對字符串的處理是極為重要的,且出現(xiàn)也較為頻繁斯嚎,R語言作為當(dāng)前最為流行的開源數(shù)據(jù)分析和可視化平臺...
    果果哥哥BBQ閱讀 5,793評論 0 8
  • 說不清楚為什么利虫,總是不喜歡雨,所以更不喜歡下雨天堡僻,不論春雨還是冬雨糠惫。 小學(xué)時(shí),下雨天上學(xué)的路總是很泥濘钉疫,...
    九月果醬閱讀 857評論 0 0