0.對于HTTP協(xié)議而言,HTML、CSS、JS、JSON的本質(zhì)是什么?
- 對于HTTP協(xié)議而言,HTML、CSS、JS、JSON的本質(zhì)是符合相應語法的字符串。
1.使用數(shù)組拼接出如下字符串 ,其中styles數(shù)組里的個數(shù)不定
var prod = {
name: '女裝',
styles: ['短款', '冬季', '春裝']
};
function getTpl(data){
//todo...
};
var result = getTplStr(prod); //result為下面的字符串
<dl class="product"><dt>女裝</dt><dd>短款</dd<dd>冬季</dd><dd>春裝</dd></dl>
var prod = {
name: '女裝',
styles: ['短款', '冬季', '春裝']
};
function getTplStr(data){
var result
var i
result = '<dl class="product"><dt>' + data.name + '</dt>'
for(i = 0; i < data.styles.length; i ++){
result += '<dd>' + data.styles[i] + '</dd>'
}
result += '</dl>'
return result
};
var result = getTplStr(prod);
console.log(result)
2.寫出兩種以上聲明多行字符串的方法
var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
var str = 'abcdeabcdeabcdeancdabcdea' +
'bcdeabcdeancdeabcdeabcdea' +
'bcdeancdeabcdeabcdeabcdea' +
'ncde'
var str = 'abcdeabcdeabcdeancdabcdea\
bcdeabcdeancdeabcdeabcdea\
bcdeancdeabcdeabcdeabcdea\
ncde'
3.補全如下代碼,讓輸出結果為字符串: hello\\饑人谷
var str = 'hello\\\\饑人谷'
console.log(str)
4.以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length) // 輸出13,`\n`是轉(zhuǎn)義字符,代表換行,實際上是一個字符
5.寫一個函數(shù),判斷一個字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
function huiwen(c){
var str
str = c.split().reverse().join('')
return str === c
}
6、寫一個函數(shù),統(tǒng)計字符串里出現(xiàn)出現(xiàn)頻率最多的字符
function mostTimesChar(str){
var i
var dic = {}
for(i = 0; i < str.length; i ++){
if(dic[str[i]]){
dic[str[i]] ++
}else{
dic[str[i]] = 1
}
}
var count = 0
var mostChar
for (var key in dic) {
if (dic[key] > count){
count = dic[key]
maxCh = key
}
}
console.log('出現(xiàn)最多的字母是' + key + ',出現(xiàn)了' + count + '次')
}
7.寫一個camelize函數(shù),把my-short-string形式的字符串轉(zhuǎn)化成myShortString形式的字符串,如
camelize("background-color") == 'backgroundColor'
camelize("list-style-image") == 'listStyleImage'
function camelize(c){
var str1
var str = c.split('-')
for(var i = 1; i < str.length; i++){
str1 = str[i].charAt(0).toUpperCase()
str[i] = str1 + str[i].substr(1,str[i].length)
}
str = str.join('')
return str
}
8.寫一個 ucFirst函數(shù),返回第一個字母為大寫的字符
ucFirst("hunger") == "Hunger"
function ucFirst(c){
var str
var str1 = c.substr(0,1)
var str2 = c.substr(1,c.length - 1)
str = str1.toUpperCase() + str2
return str
}
function ucFirst(c){
var str = c.charAt(0).toUpperCase() + c.substr(1,c.length - 1)
return str
}
9.寫一個函數(shù)truncate(str, maxlength), 如果str的長度大于maxlength,會把str截斷到maxlength長,并加上...,如
truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"
function truncate(str, maxlength){
var newStr
if(maxlength < str.length){
newStr = str.substr(0,maxlength) + '...'
}
else{
newStr = str
}
return newStr
}
10.什么是 JSON格式數(shù)據(jù)?JSON格式數(shù)據(jù)如何表示對象?window.JSON 是什么?
什么是 JSON格式數(shù)據(jù)
- JSON 格式(JavaScript Object Notation 的縮寫)是一種輕量級的數(shù)據(jù)交換格式,2001年由 Douglas Crockford 提出,目的是取代繁瑣笨重的 XML 格式。易于人閱讀和編寫。同時也易于機器解析和生成。 它是JS對象語法的一個子集,JSON采用完全獨立于語言的文本格式,但是也使用了類似于C語言家族的習慣(包括C, C++, C#, Java, JavaScript, Perl, Python等)。這些特性使JSON成為理想的數(shù)據(jù)交換語言。
JSON格式數(shù)據(jù)如何表示對象
- 并列的數(shù)據(jù)之間用逗號(", ")分隔。
- 映射用冒號(": ")表示。
- 并列數(shù)據(jù)的集合(數(shù)組)用方括號("[]")表示。
- 映射的集合(對象)用大括號("{}")表示
window.JSON 是什么
- 用于判斷瀏覽器是否兼容JSON的用法(IE8版本以上都內(nèi)置支持JSON)。
- 可以用于模仿原生JSON對象,讓舊版(沒有原生支持JSON)瀏覽器可以使用JSON對象
11.如何把JSON 格式的字符串轉(zhuǎn)換為 JS 對象?如何把 JS對象轉(zhuǎn)換為 JSON 格式的字符串?
- JSON.parse() 可以把一個JSON格式字符串轉(zhuǎn)化成JSON對象
- JSON.stringify() 可以把一個JS對象轉(zhuǎn)化成JSON 字符串。