1、使用數(shù)組拼接出如下字符串 ,其中styles數(shù)組里的個(gè)數(shù)不定
var prod = {
name: '女裝',
styles: ['短款', '冬季', '春裝']
};
function getTplStr(data){
var str = '';
var str1 = '';
for(var i=0;i<data.styles.length;i++){
str1+='<dd>'+data['styles'][i]+'</dd>'+'\n';
}
str = '<dl class="product">'+'\n'+'<dt>'+data['name']+'</dt>'+'\n'+str1+'</dl>';
return str;
};
var result = getTplStr(prod);
console.log(result);
2、寫出兩種以上聲明多行字符串的方法
var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde';
var str1 = 'abcdeabcd\
eabcdean\
cdeabcde\
abcdeabcd\
eancdeabc\
deabcdeab\
cdeancdea\
bcdeabc\
deabc\
deancde';
var str2 = 'abcdeab'+
'cdeabcde'+
'ancdeabc'+
'deabcdea'+
'bcdeancd'+
'eabcdeab'+
'cdeabcdea'+
'ncdeabcd'+
'eabcde'+
'abcdeancde';
var str3 = (function () {/*
cdeabcde
cdeancdea
bcdeadeab
deabcdea
*/}).toString().split('\n').slice(1,-1).join('\n');
console.log(str);
console.log(str1);
console.log(str2);
console.log(str3);
3、補(bǔ)全如下代碼,讓輸出結(jié)果為字符串: hello\饑人谷
var str = 'hello\\\\饑人谷'
console.log(str);
4、以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu';
console.log(str.length);//13因?yàn)閈n是一個(gè)換行符相當(dāng)于一個(gè)字符,length就為13
5、寫一個(gè)函數(shù),判斷一個(gè)字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
function isReverse(str) {
var str1 = str.split('').reverse().join('');
return str == str1;
};
console.log(isReverse('abcdcba'));//true
console.log(isReverse('abcdefg'));//false
6、寫一個(gè)函數(shù),統(tǒng)計(jì)字符串里出現(xiàn)出現(xiàn)頻率最多的字符
var obj = {};
var mostCode;
var count = 0;
function judgeMost(str) {
var arr = str.split('');
for(var i=0;i<arr.length;i++){
if(obj[arr[i]]){
obj[arr[i]]++;
}else {
obj[arr[i]] = 1;
}
}
for(var key in obj){
if(obj[key]>count){
mostCode = key;
count = obj[key];
}
}
return mostCode;
}
console.log(judgeMost('aaaaaaaaaaaaaaabbbccccccc'));//a
console.log(obj);//{a:15,b:3,c:7}
7、寫一個(gè)camelize函數(shù),把my-short-string形式的字符串轉(zhuǎn)化成myShortString形式的字符串,如camelize("background-color") == 'backgroundColor',camelize("list-style-image") == 'listStyleImage'
function camelize(str) {
var arr = str.split('-');
for(var i=0;i<arr.length;i++){
if(i>0){
var str1 = arr[i].charAt(0).toUpperCase();
arr[i] = arr[i].replace(arr[i].charAt(0),str1);
}
}
return arr.join('');
}
var result = camelize('list-style-image');
console.log(result);//listStyleImage
8、寫一個(gè) ucFirst函數(shù),返回第一個(gè)字母為大寫的字符 (***)
ucFirst("hunger") == "Hunger"
function ucFirst(str) {
var str1 = str.charAt(0).toUpperCase();
str = str.replace(str.charAt(0),str1);
return str;
}
var result = ucFirst('str');
console.log(result);//Str
9、寫一個(gè)函數(shù)truncate(str, maxlength), 如果str的長(zhǎng)度大于maxlength,會(huì)把str截?cái)嗟絤axlength長(zhǎng),并加上...,如truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"
function truncate(str, maxlength){
if(str.length>maxlength){
str = str.substr(0,maxlength)+'...';
}
return str;
}
var result = truncate('hello world', 8);
console.log(result);//hello wo...
10、什么是 JSON格式數(shù)據(jù)?JSON格式數(shù)據(jù)如何表示對(duì)象?window.JSON 是什么?
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式;
JSON數(shù)據(jù)格式:
數(shù)據(jù)在名稱/值對(duì)中;數(shù)據(jù)由逗號(hào)分隔;花括號(hào)保存對(duì)象;方括號(hào)保存數(shù)組。JSON 數(shù)據(jù)的書寫格式是:名稱/值對(duì),名稱/值對(duì)組合中的名稱寫在前面(在雙引號(hào)中),值對(duì)寫在后面(同樣在雙引號(hào)中),中間用冒號(hào)隔開:;
ES5已經(jīng)內(nèi)置了JSON對(duì)象;JSON對(duì)象主要有兩個(gè)『靜態(tài)』函數(shù):
- parse:把字符串轉(zhuǎn)化為JSON對(duì)象
- stringify:把JSON對(duì)象轉(zhuǎn)化為字符串(出人意料的不叫toString,因?yàn)椴皇菍?shí)例方法)
11、如何把JSON 格式的字符串轉(zhuǎn)換為 JS 對(duì)象?如何把 JS對(duì)象轉(zhuǎn)換為 JSON 格式的字符串?
JSON.parse();//轉(zhuǎn)換為對(duì)象
JSON.stringify();//轉(zhuǎn)換為字符串