字符串與JSON

  1. 使用數(shù)組拼接出如下字符串 ,其中styles數(shù)組里的個數(shù)不定
var prod = {
    name: '女裝',
    styles: ['短款', '冬季', '春裝']
};
function getTpl(data){
  var arr = []
  arr.push('<dl class="product">')
  arr.push('<dt>' + data.name + '</dt>')
  for (var key in data.styles) {
    arr.push('<dd>' + data.styles[key] + '</dd>')
  }
  arr.push('</dl>')
  var str = arr.join('')
  return str
};
var result = getTpl(prod);  //result為下面的字符串
console.log(result)

<dl class="product"><dt>女裝</dt><dd>短款</dd><dd>冬季</dd><dd>春裝</dd></dl>
  1. 寫出兩種以上聲明多行字符串的方法搅方,這段字符串很長煌集,如何多行優(yōu)雅的顯示
var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
1. 在每一行的尾部使用反斜杠\
2. 連接運算符(+)拼接接多個單行字符串
3. 利用多行注釋
(function() { /*
line 1
line 2
line 3
*/}).toString().split('\n').slice(1,-1).join('\n')
  1. 補全如下代碼,讓輸出結(jié)果為字符串: hello\\饑人谷
var str = 'hello\\\\饑人谷'  //補全代碼
console.log(str)
  1. 以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length)  //13,換行符 \n 占一個字符
  1. 寫一個函數(shù)黔州,判斷一個字符串是回文字符串,如 abcdcba 是回文字符串, abcdcbb 不是
//方法一
(function isPalindrome(str) {
  var str = 'abcdcba'
  return str === str.split("").reverse().join("")
}())


//方法二
function isPalindrome(str) {
  str = str.toLowerCase();
  str = str.replace(/[\ \,\.\:\_\/\\\(\)\-]/g,'');
  for(var i=0,j=str.length-1;i<j;i++,j--){
    if(str.charAt(i) !== str.charAt(j)){
      return false;
    }
  }
  return true;
}
var str = 'abba'
var str1 = '12345'
console.log(isPalindrome(str))  //true
console.log(isPalindrome(str1))  //false
  1. 寫一個函數(shù)阔籽,統(tǒng)計字符串里出現(xiàn)出現(xiàn)頻率最多的字符
var str = 'hello '
var dict = {}
for(var i = 0, i < str.length, i++) {
  if(dict[str[i]]) {
    ++dict[str[i]]
  } else {
    dict[str[i]] = 1
  }
}

var count = 0
var maxValue
for(key in dict) {
  if(dict[key]) > count {
    maxValue = key
    count = dict[key]
  }
}
console.log(count, maxValue)
  1. 寫一個camelize函數(shù)流妻,把my-short-string形式的字符串轉(zhuǎn)化成myShortString形式的字符串
function camelize(str) {
  var arr = str.toLowerCase().split("-")
  var result = ''
  for(var i = 1; i < arr.length; i++) {
    result += arr[i].substring(0,1).toUpperCase() + arr[i].substring(1);
  }
  var result = arr[0]+result
  return result;
}
camelize("background-color") == 'backgroundColor'
camelize("list-style-image") == 'listStyleImage'
  1. 寫一個 ucFirst函數(shù),返回第一個字母為大寫的字符 (***)
function ucFirst(str) {
  var str = str.replace(str.charAt(0), str.charAt(0).toUpperCase())
  return str
}
ucFirst("hunger") == "Hunger"
  1. 寫一個函數(shù)truncate(str, maxlength), 如果str的長度大于maxlength笆制,會把str截斷到maxlength長绅这,并加上...,
function truncate(str, maxlength) {
  if (maxlength < str.length) {
    return str.substr(0, maxlength) + '...'
  } else {
    return str
  }
}
truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"
  1. 什么是 JSON 格式數(shù)據(jù)在辆?JSON 格式數(shù)據(jù)如何表示對象君躺?window.JSON 是什么?
  • JSON 是一種輕量級的數(shù)據(jù)交換格式开缎,指的是 JavaScript 對象表示法(JavaScript Object Notation),采用完全獨立于語言的文本格式
  • JSON 對象是一個無序的 “鍵/值” 對的集合:“名稱: 值”林螃;一個對象以 “{” 開始奕删,以“}” 結(jié)束;每個“名稱”后跟一個“:”(冒號)疗认;“‘名稱: 值’ 對”之間使用 “,” 分隔
    例如:{ "firstName": "John" , "lastName": "Doe" }
  • window.JSON是瀏覽器的內(nèi)置對象完残,可用于判斷瀏覽器是否兼容JSON的用法;例如 IE8 及以上版本才內(nèi)置支持 JSON.parse() 和 JSON.stringify() 方法
  1. 如何把JSON 格式的字符串轉(zhuǎn)換為 JS 對象横漏?如何把 JS 對象轉(zhuǎn)換為 JSON 格式的字符串?
  • JSON.parse() 方法用于將一個 JSON 字符串轉(zhuǎn)換為對象
    例如:JSON.parse('{"name": "Mark", "age": 50}')
  • JSON.stringify() 方法用于將 JavaScript 值轉(zhuǎn)換為 JSON 字符串谨设,可以被 JSON.parse() 還原
    例如:JSON.stringify({name: "Mark", age: 50})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市缎浇,隨后出現(xiàn)的幾起案子扎拣,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件二蓝,死亡現(xiàn)場離奇詭異誉券,居然都是意外死亡,警方通過查閱死者的電腦和手機刊愚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門踊跟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鸥诽,你說我怎么就攤上這事商玫。” “怎么了牡借?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵拳昌,是天一觀的道長。 經(jīng)常有香客問我蓖捶,道長地回,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任俊鱼,我火速辦了婚禮刻像,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘并闲。我一直安慰自己细睡,他們只是感情好,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布帝火。 她就那樣靜靜地躺著溜徙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪犀填。 梳的紋絲不亂的頭發(fā)上蠢壹,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機與錄音九巡,去河邊找鬼图贸。 笑死,一個胖子當著我的面吹牛冕广,可吹牛的內(nèi)容都是我干的疏日。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼撒汉,長吁一口氣:“原來是場噩夢啊……” “哼沟优!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起睬辐,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤挠阁,失蹤者是張志新(化名)和其女友劉穎宾肺,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鹃唯,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡爱榕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了坡慌。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片黔酥。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖洪橘,靈堂內(nèi)的尸體忽然破棺而出跪者,到底是詐尸還是另有隱情,我是刑警寧澤熄求,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布渣玲,位于F島的核電站,受9級特大地震影響弟晚,放射性物質(zhì)發(fā)生泄漏忘衍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一卿城、第九天 我趴在偏房一處隱蔽的房頂上張望枚钓。 院中可真熱鬧,春花似錦瑟押、人聲如沸搀捷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嫩舟。三九已至,卻和暖如春怀偷,著一層夾襖步出監(jiān)牢的瞬間家厌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工椎工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留像街,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓晋渺,卻偏偏與公主長得像,于是被迫代替她去往敵國和親脓斩。 傳聞我的和親對象是個殘疾皇子木西,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355