字符串和JSON

  1. 使用數組拼接出如下字符串
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>
  1. 寫出兩種以上聲明多行字符串的方法
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"
  1. 補全如下代碼,讓輸出結果為字符串: hello\饑人谷
var str = 'hello\\\\饑人谷'    //一個字符串中的反斜杠 需要反斜杠前再加一個反斜杠,用來對自身轉義,所以有四個反斜杠
console.log(str)
  1. 以下代碼輸出什么?為什么
var str = 'jirengu\nruoyu'
console.log(str.length)
//輸出為13
"jirengu     //轉行符也占一個字符,jirengu后有一個空格
    ruoyu" 
  1. 寫一個函數,判斷一個字符串是回文字符串,如 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))
  1. 寫一個函數,統計字符串里出現出現頻率最多的字符
// 寫一個函數,統計字符串里出現出現頻率最多的字符
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)
  1. 寫一個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'
  1. 寫一個 ucFirst函數,返回第一個字母為大寫的字符 (***)
function ucFirst(str){
      var first = str.charAt(0).toUpperCase()
      var other = str.slice(1)
      return console.log(first + other)
}
ucFirst("hunger") == "Hunger"
  1. 寫一個函數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"
  1. 什么是 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()方法分別來實現上述兩項功能
  1. 如何把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))) 
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 1.使用數組拼接出如下字符串 2.寫出兩種以上聲明多行字符串的方法 字符串拼接 用\來轉義換行符號,\后面沒空格 ...
    饑人谷_tonya閱讀 482評論 1 0
  • 1.使用數組拼接出如下字符串。 結果如下 2.寫出兩種以上聲明多行字符串的方法 用轉義符 \n1. var ...
    饑人谷_羅丹閱讀 394評論 0 0
  • 0、對于 HTTP 協議而言,HTML、CSS、JS、JSON 的本質都是什么? HTTP是基于TCP/IP協議的...
    zx9426閱讀 1,922評論 0 0
  • *0、對于 HTTP 協議而言,HTML、CSS、JS、JSON 的本質都是什么? 都是字符串。瀏覽器根據相應請求...
    7a9d36c8963d閱讀 187評論 0 0
  • 1.使用數組拼接出如下字符串 };```function getTpl(data){var arr = "";fo...
    湖衣閱讀 333評論 0 0