1.使用數(shù)組拼接出如下字符串。
var prod = {
name: '女裝',
styles: ['短款' ,'冬季' ,'春裝']
};
function getTplStr(data){
//
};
var result = getTplStr(prod);//result為下面的字符串
<dl class="product">
<dt>女裝</dt>
<dd>短款</dd>
<dd>冬季</dd>
<dd>春裝</dd>
</dl>
結(jié)果如下
var prod = {
name: '女裝',
styles: ['短款' ,'冬季' ,'春裝']
};
function getTplStr(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>');
return arr.join('');
};
var result = getTplStr(prod);//result為下面的字符串
console.log(result);
//結(jié)果
<dl class="product"><dt>女裝</dt><dd>短款</dd><dd>冬季</dd><dd>春裝</dd></dl>
2.寫出兩種以上聲明多行字符串的方法
- 用轉(zhuǎn)義符 \n
1. var a = "hello\nworld";
console.log(a); - 用反引號`..
var a =
hello
world`
console.log(a); - 用數(shù)組的join方法
var arr = [a , b ,c ];
var x = arr.join("\n");
console.log(x);
3.補(bǔ)全如下代碼,讓輸出結(jié)果為字符串: hello\\饑人谷
var str = //補(bǔ)全代碼
console.log(str)
補(bǔ)全如下
var str = "hello\\\饑人谷"智厌;
4以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length)
輸出代碼如下
console.log(str.length);// 13
因?yàn)閈n是轉(zhuǎn)義符換行的意思只能算作一個诲泌。
5寫一個函數(shù),判斷一個字符串是回文字符串铣鹏,如 abcdcba是回文字符串, abcdcbb不是
function isPalindrome(str){
return str === str.split('').reverse().join('');
}
isPalindrome('abcdcba'); // true
6寫一個函數(shù)敷扫,統(tǒng)計(jì)字符串里出現(xiàn)出現(xiàn)頻率最多的字符.
function Foo(x){
var arr = {};
for(var i = 0; i<x.length; i++){
if(arr[x[i]] !== undefined){
++arr[x[i]];
}else{
arr[x[i]] = 1;
}
}
var count = 0; //計(jì)數(shù)出現(xiàn)幾次
var maxstr = null; // 重復(fù)最多的字符
var a = "出現(xiàn)頻率最多的字符是:";
var b = "出現(xiàn)的次數(shù)為:";
for(var key in arr){
if(arr[key] > count){
maxstr = key;
count = arr[key];
}
}
return a+maxstr+'\n'+b+count;
}
console.log(Foo('sdfewfsjfksdjfhewufhawef'));
//出現(xiàn)頻率最多的字符是:f
//出現(xiàn)的次數(shù)為:6
7. 寫一個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 = 1, i<arr.length; i++){
arr[i]=arr[i][0].toUpperCase()+arr[i].substr(1);
}
}
console.log(camelize("background-color")) // 'backgroundColor'
console.log(camelize("list-style-image")) // 'listStyleImage'
8葵第、寫一個 ucFirst函數(shù),返回第一個字母為大寫的字符 (***)
function ucFirst(STR){
return STR[0].toUpperCase() + STR.slice[1];
}
console.log(ucFirst('string'));// String
9合溺、寫一個函數(shù)truncate(str, maxlength), 如果str的長度大于maxlength卒密,會把str截?cái)嗟絤axlength長,并加上...棠赛,如
truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"
過程如下
function truncate(str,maxlength){
var arr = [];
for(var i = 0; i<str.length; i++){
if( i === maxlength){
arr.push('...');
break;
}else{
arr.push(str[i]);
}
}
var arr1 = arr.join('');
return arr1;
}
console.log(truncate('hello, this is hunger valley,', 10)); // hello, thi...
console.log(truncate("hello world", 20));// hello world
10哮奇、什么是 JSON格式數(shù)據(jù)?JSON格式數(shù)據(jù)如何表示對象睛约?window.JSON 是什么鼎俘?
- JSON格式(JavaScript Object Notation)是一種用于數(shù)據(jù)交換的文本格式辩涝。
- 簡單的說,每個JSON對象捉邢,就有一個值,要么是簡單類型值伏伐,要么是復(fù)合類型的值,但只能有一個值藐翎。
-
JSON對值的類型和格式有嚴(yán)格的規(guī)定
- 復(fù)合類型的值只能是數(shù)組或?qū)ο螅荒苁呛瘮?shù)、正則表達(dá)式茬缩、日期對象。
- 簡單類型的值有四種: 字符串凰锡、數(shù)值(必須是十進(jìn)制表示)、布爾值和
null(不能使用NaN,Infinity裕膀,-Infinity和undefined). - 字符串必須雙引號表示勇哗,不能使用單引號。
- 對象的鍵名必須放在雙引號里面抄谐。
- 數(shù)組或?qū)ο笞詈笠粋€成員的后面,不能加逗號蛹含。
- window.JSON : 是瀏覽器內(nèi)置對象塞颁。可用于判斷瀏覽器是否兼容JSON的用法.
11酷窥、如何把JSON 格式的字符串轉(zhuǎn)換為 JS 對象?如何把 JS對象轉(zhuǎn)換為 JSON 格式的字符串?
- JSON.stringify()方法用于將一個值轉(zhuǎn)換成字符串竖幔。該字符串符合JSON格式是偷,并且可以被JSON.parse方法還原募逞。