- 使用數(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>
- 寫出兩種以上聲明多行字符串的方法搅方,這段字符串很長煌集,如何多行優(yōu)雅的顯示
var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
1. 在每一行的尾部使用反斜杠\
2. 連接運算符(+)拼接接多個單行字符串
3. 利用多行注釋
(function() { /*
line 1
line 2
line 3
*/}).toString().split('\n').slice(1,-1).join('\n')
- 補全如下代碼,讓輸出結(jié)果為字符串:
hello\\饑人谷
var str = 'hello\\\\饑人谷' //補全代碼
console.log(str)
- 以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length) //13,換行符 \n 占一個字符
- 寫一個函數(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
- 寫一個函數(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)
- 寫一個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'
- 寫一個 ucFirst函數(shù),返回第一個字母為大寫的字符 (***)
function ucFirst(str) {
var str = str.replace(str.charAt(0), str.charAt(0).toUpperCase())
return str
}
ucFirst("hunger") == "Hunger"
- 寫一個函數(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"
- 什么是 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() 方法
- 如何把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})