隨筆記錄--JS 中關于字符串的一些細節(jié)

在JS中所有用單引號或者雙引號包起來的都是字符串,每個字符串都是有零到多個字符組成啡彬。

上一篇介紹了數(shù)組中的常方法羹与,可以與字符串中的方法進行對比

關于字符串中常用的方法

字符串是基本數(shù)據(jù)類型,字符串的每次操作都是對值的直接進行操作庶灿,和數(shù)組不一樣纵搁,數(shù)組是基于空間地址來操作的,所以不存在原有字符串是否改變的說法往踢,肯定都是不變的腾誉。

charAt/charCodeAt

作用:charCodeAt不僅僅獲取字符,它獲取的是字符對應 的Unicode編碼值(ASC II碼值)
參數(shù):索引
返回:字符或者對應的編碼

var str = "xiaoKge_2";
console.log(str.charAt(0)); //'x' 獲取索引為0的字符

通過charAt獲取和直接操作索引方式獲取的區(qū)別:

  • 當索引不存在的時候峻呕,str[x]獲得的結果是undefined利职,運行的機制和對象是一樣的,而charAt(x)獲取的結果是空字符串瘦癌。

charCodeAt返回的是字符串對應的編碼
fromCharCode返回的是編碼對應的字符

console.log(str.charCodeAt(0)); //120
//返回的是字符對應的編碼
console.log(String.fromCharCode(120));  //'x'

slice

作用: str.slice(n,m) 從索引n開始找到索引為m處(不 包含m)猪贪,把找到的字符當做新字符串返回。
和數(shù)組中的slice操作是一樣的:不寫m是查找到字符串的末尾讯私,n/m都不寫是字符串的克隆热押,,支持負數(shù)索引斤寇,用字符串的總長度+負數(shù)索引做運算

var str = "xiaoKge_2";
console.log(str.slice(2,7));//aoKge
console.log(str.slice());  //xiaoKge_2
console.log(str.slice(-3,-1));  //e_

substring

和slice語法一模一樣桶癣,唯一的區(qū)別在于:slice支持負數(shù)索引,而substring不支持負數(shù)索引娘锁。

substr

字符串截取的方法牙寞,用法是:str.substr(n,m),從索引n開始截取m個字符。

var str = "xiaoKge_2";
console.log(str.substr(2,5));  //aoKge
console.log(str.substr(2)); //aoKge_2
console.log(str.substr(-3,1));  //e

split

和數(shù)組中的join相對應莫秆,數(shù)組中的join是把數(shù)組一項按照指定的連接符變?yōu)樽址淙福鴖plit是把字符串按照指定的分隔符,拆分成數(shù)組中每一項镊屎。

var ary = [12,13,14];
var str = ary.join("+");
console.log(str);  //12+13+14
console.log(str.split('+')); // ["12", "13", "14"]

replace

作用:替換字符串中的原有字符
參數(shù):原有字符惹挟,要替換的新字符
返回值:返回替換后的字符串

var str = "xiaoKge_2";
console.log(str.replace('xiao','小'));//小Kge_2xiao

在不適用正則的情況下,每執(zhí)行一次只能替換最前的的一個杯道。

console.log(str.replace(/xiao/g,'小'));  //小Kge_2小

項目中的需求案例

1.時間字符串格式化

有一個時間字符串 “2018--4--4 16:26:8” ,我們想 基于這個字符串獲取到 “04月04日 16時26分”

//04月04日 16時26分
var str = "2018--4--4 16:26:8";
var ary = str.split(' ');  //["2018--4--4", "16:26:8"]
var aryLeft = ary[0].split('-');
var aryRight = ary[1].split(':');

var month = addZero(aryLeft[1]);
var day = addZero(aryLeft[2]);
var hour = addZero(aryRight[0]);
var minute = addZero(aryRight[1]);

var result = month + '月' + day + '日' + ' ' + hour + '時' + minute + '分';
console.log(result);   //04月-4日 16時26分

function addZero(val) {
    return val < 10 ? '0' + val : val;
}

URL地址問號傳參解析

有一個URL地 址“http://www.zhufengpeixun.cn/stu/? lx=1&name=AA&sex=man” 地址問號后面的內 容是我們需要解析出來的參數(shù)信息
{
lx:1,
name:’AA’,
sex:’man’
}

// 獲取“责蝠?” 和 “#”字符所在的位置
var indexASK = str.indexOf('?'),
    indexWELL = str.indexOf('#');
//但是#號可能沒有
if(indexWELL > -1) {
    //存在#號党巾,獲取到#號位置
    str = str.substring(indexASK+1,indexWELL);
    console.log(str);
}else {
    //不存在#號,就直接獲取到字符串末尾
    str = str.substring(indexASK + 1);  //不指定第二個參數(shù)就直接獲取到字符串末尾
    // 或者使用subStr()  和上面的區(qū)別是第二個參數(shù)是個數(shù)不是位置
    // str = str.substr(indexASK+1);
    console.log(str);
}
var ary = str.split('&');
//定義一個對象來存
var obj = {};
console.log(ary);  //["lx=1", "name=AA", "sex=man"]

for(var i=0;i<ary.length;i++) {
    var itemAry = ary[i].split('=');
    var key = itemAry[0];
    var value = itemAry[1];
    obj[key] = value;
}
console.log(obj);  //{lx: "1", name: "AA", sex: "man"}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末霜医,一起剝皮案震驚了整個濱河市齿拂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌肴敛,老刑警劉巖署海,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吗购,死亡現(xiàn)場離奇詭異,居然都是意外死亡砸狞,警方通過查閱死者的電腦和手機捻勉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來刀森,“玉大人踱启,你說我怎么就攤上這事⊙械祝” “怎么了埠偿?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長榜晦。 經(jīng)常有香客問我冠蒋,道長,這世上最難降的妖魔是什么乾胶? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任抖剿,我火速辦了婚禮,結果婚禮上胚吁,老公的妹妹穿的比我還像新娘牙躺。我一直安慰自己,他們只是感情好腕扶,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布孽拷。 她就那樣靜靜地躺著,像睡著了一般半抱。 火紅的嫁衣襯著肌膚如雪脓恕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天窿侈,我揣著相機與錄音炼幔,去河邊找鬼。 笑死史简,一個胖子當著我的面吹牛乃秀,可吹牛的內容都是我干的。 我是一名探鬼主播圆兵,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼跺讯,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了殉农?” 一聲冷哼從身側響起刀脏,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎超凳,沒想到半個月后愈污,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體耀态,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年暂雹,在試婚紗的時候發(fā)現(xiàn)自己被綠了首装。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡擎析,死狀恐怖簿盅,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情揍魂,我是刑警寧澤桨醋,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站现斋,受9級特大地震影響喜最,放射性物質發(fā)生泄漏。R本人自食惡果不足惜庄蹋,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一瞬内、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧限书,春花似錦虫蝶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至扰柠,卻和暖如春粉铐,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卤档。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工蝙泼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人劝枣。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓汤踏,卻偏偏與公主長得像,于是被迫代替她去往敵國和親舔腾。 傳聞我的和親對象是個殘疾皇子溪胶,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345