- 使用數組拼接出如下字符串
var prod = {
name: '女裝',
styles: ['短款', '冬季', '春裝']
};
function getTpl(data){
var arr = new Array();
arr[0] = '<dl class="product">'
arr[1] = ' <dt>' + prod.name + '</dt>'
for(i=0;i<data.styles.length;i++){
arr[i+2]=' <dd>' + data.styles[i] + '</dd>'
}
arr.push('</dl>')
return arr.join('\n')
}
var result = getTpl(prod);
console.log(result)
//輸出
<dl class="product">
<dt>女裝</dt>
<dd>短款</dd>
<dd>冬季</dd>
<dd>春裝</dd>
</dl>
- 寫出兩種以上聲明多行字符串的方法
var longString = "Long \n\ //每一行后加反斜杠\ 原來寫在一行的字符串,可以分成多行,效果與寫在同一行完全一樣
long \n\
long \n\
string";
console.log(longString)
//輸出為
"Long
long
long
string"
var longString = "Long \n"+ //連接運算符(+)可以連接多個單行字符串,用來模擬多行字符串。
"long \n"+
"long \n"+
"string";
console.log(longString)
//輸出為
"Long
long
long
string"
- 補全如下代碼,讓輸出結果為字符串: hello\饑人谷
var str = 'hello\\\\饑人谷' //一個字符串中的反斜杠 需要反斜杠前再加一個反斜杠,用來對自身轉義,所以有四個反斜杠
console.log(str)
- 以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length)
//輸出為13
"jirengu //轉行符也占一個字符,jirengu后有一個空格
ruoyu"
- 寫一個函數,判斷一個字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
var a = 'abcdcba'
var b = 'abcdefg'
var c = 'abcdecba'
function isPalindrome(str){
var arr = str.split('')
for(i=0;i<arr.length;i++){
if(arr[i]!==arr[arr.length-1-i]){
return false
}
}
return true
}
console.log(isPalindrome(a))
console.log(isPalindrome(b))
console.log(isPalindrome(c))
- 寫一個函數,統計字符串里出現出現頻率最多的字符
// 寫一個函數,統計字符串里出現出現頻率最多的字符
var str = 'lsakdhlsahflkasjdlkxcnkahloweiuqwokjdsk'
function find(str){
var list = {}
for(i=0;i<str.length;i++){
if(list[str[i]]){
list[str[i]]++
}else{
list[str[i]]=1
}
}
// console.log(list)
var inc = str[0]
for(key in list){
if(list[key]>list[inc]){
inc = key
}
}
console.log('最大值是'+'\"'+inc+'\",'+' 出現次數 '+ list[inc])
}
find(str)
- 寫一個camelize函數,把my-short-string形式的字符串轉化成myShortString形式的字符串,如
function camelize(str){
var a = []
var arr = []
a = str.split('-')
for(i=1;i<a.length;i++){
arr[i-1]=a[i].charAt(0).toUpperCase()+a[i].slice(1);
}
arr.unshift(a[0])
return arr.join('')
}
console.log(camelize("background-color"))// == 'backgroundColor'
console.log(camelize("list-style-image")) //== 'listStyleImage'
- 寫一個 ucFirst函數,返回第一個字母為大寫的字符 (***)
function ucFirst(str){
var first = str.charAt(0).toUpperCase()
var other = str.slice(1)
return console.log(first + other)
}
ucFirst("hunger") == "Hunger"
- 寫一個函數truncate(str, maxlength), 如果str的長度大于maxlength,會把str截斷到maxlength長,并加上...,如
function truncate(str,maxlength){
if(str.length > maxlength){
return str.slice(0,maxlength)+ '...'
}else{
return str
}
}
console.log(truncate("hello, this is hunger valley,", 10))
console.log(truncate("hello world", 20))
// truncate("hello, this is hunger valley,", 10)) == "hello, thi...";
// truncate("hello world", 20)) == "hello world"
- 什么是 json?什么是 json 對象?什么是 json 對象字面量?什么是 JSON內置對象?
- JSON(JavaScript ObjectNotation,JavaScript對象表示法),是js的一個嚴格的子集,利用了js中的一些模式來表示結構化數據
- JSON對象作為一種復雜數據類型,表示一組無序的鍵值對。而每個鍵值對中的值可以是簡單值也可以是復雜數據類型的值
//js中的對象
var person = {
name : "jirengu" ,
age : 28
};
//JSON中
{
"name" : "jirengu", //字符串和鍵名要在雙引號里
"age" : 28 //最后一行不能加逗號
}
- {花括號內的內容就是json對象字面量 }
- ES5定義了一個原生的JSON對象,可以用來將對象序列化為JSON字符串或者將JSON數據解析為JavaScript對象。JSON.stringify()和JSON.parse()方法分別來實現上述兩項功能
- 如何把JSON 格式的字符串轉換為對象?如何把對象轉換為 JSON 格式的字符串?
前一個用JSON.parse()方法,后一個用方法JSON.stringify()
var person = {
'name' : 'jirengu' ,
'age' : 28
};
console.log(person)
console.log(JSON.stringify(person))
console.log(JSON.parse(JSON.stringify(person)))