JS的引用類型與拷貝

1、使用數(shù)組拼接出如下字符串


var prod = {
    name: '女裝',
    styles: ['短款', '冬季', '春裝']
  };

function getTpl(data){
   var arr=[]
   arr.push('<dl class="product">')
   arr.push('      <dt>'+data.name+'</dt>')
   for(var i=0;i<product.styles.length;i++){
     arr.push('<dd>'+data.styles[i]+'</dd>')
   }
  arr.push('</dl>');
  return arr.join('');

};

var result = getTpl(prod);  
console.log(result);                                                     

2、寫出兩種以上聲明多行字符串的方法

(1)var longString = "Long \
long \
long \
string";

longString
// "Long long long string"

(2)var longString = 'Long '
  + 'long '
  + 'long '
  + 'string'

(3)(function () { /*
line 1
line 2
line 3
*/}).toString().split('\n').slice(1,-1).join('\n')
// "line 1 line 2 line 3"

3、補(bǔ)全如下代碼,讓輸出結(jié)果為字符串: hello\饑人谷

var str = 'hello\\\\饑人谷'//補(bǔ)全代碼
console.log(str)

4、以下代碼輸出什么?為什么

var str = 'jirengu\nruoyu'
console.log(str.length)//13;反斜杠只是換行的作用,打印的str總長(zhǎng)度是13

5、寫一個(gè)函數(shù),判斷一個(gè)字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是

var str = 'abababs'
function isreverse(){
    return str == str.split('').reverse().join('')

 }
isreverse(str)

6、寫一個(gè)函數(shù),統(tǒng)計(jì)字符串里出現(xiàn)出現(xiàn)頻率最多的字符

var str = 'hello hhhhhhhhhhhhh'
var dist = {}
for (var i=0;i<str.length;i++){
    if(dist[str[i]]){
       dist[str[i]]++; 
    }else {
        dist[str[i]] = 1;
    }
}
var count =0;
var maxValue;
for(var key in dist ){
if (dist[key]>count){    
    count = dist[key];
    maxValue = key 
}
}
console.log(maxValue+count)    

7、寫一個(gè)camelize函數(shù),把my-short-string形式的字符串轉(zhuǎn)化成myShortString形式的字符串,如

camelize("background-color") == 'backgroundColor'
camelize("list-style-image") == 'listStyleImage'


 function camelize(str){
  var arr = str.split("-");
  var newArr = [];
  newArr[0] = arr[0];
  for(var i = 1;i < arr.length;i++){
    newArr.push( arr[i][0].toUpperCase() + arr[i].slice(1));
  }
  return newArr.join("");
}
var str = "happy-new-year";
console.log(camelize(str));


8、寫一個(gè) ucFirst函數(shù),返回第一個(gè)字母為大寫的字符 (***)

ucFirst("hunger") == "Hunger"
 var str='hunger'
 
 function ucFirst(){
    str=str.split('')
 for (var i = 0; i < 1; i++) {
    str[0]=str[i][0].toUpperCase() 
 }  var str1=str.join('')
return str1
}

ucFirst('hunger')

9.寫一個(gè)函數(shù)truncate(str, maxlength), 如果str的長(zhǎng)度大于maxlength,會(huì)把str截?cái)嗟絤axlength長(zhǎng),并加上...,如:

truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"




var str = "hello, this is hunger valley";
    function truncate (obj,num){
        if(obj.length>num){
            var arr = obj.split('');
            arr.splice(num,obj.length-num,"....");
            return arr.join('');
        }
        return obj;
    }
    console.log(truncate(str,10));

10、什么是 json?什么是 json 語(yǔ)言?JSON 語(yǔ)言如何表示對(duì)象?window.JSON 是什么?

JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式,易于閱讀和編寫,同時(shí)也易于機(jī)器解析和生成。。
簡(jiǎn)單說(shuō),每個(gè)JSON對(duì)象,就是一個(gè)值。要么是簡(jiǎn)單類型的值,要么是復(fù)合類型的值,但是只能是一個(gè)值,不能是兩個(gè)或更多的值。這就是說(shuō),每個(gè)JSON文檔只能包含一個(gè)值。
JSON對(duì)值的類型和格式有嚴(yán)格的規(guī)定。
JSON對(duì)象,其實(shí)就是JSON的值,基本要符合以下規(guī)則.
復(fù)合類型的值只能是數(shù)組或?qū)ο螅荒苁呛瘮?shù)、正則表達(dá)式對(duì)象、日期對(duì)象。
簡(jiǎn)單類型的值只有四種:字符串、數(shù)值(必須以十進(jìn)制表示)、布爾值和null(不能使用NaN, Infinity, -Infinity和undefined)。
字符串必須使用雙引號(hào)表示,不能使用單引號(hào)。
對(duì)象的鍵名必須放在雙引號(hào)里面。
數(shù)組或?qū)ο笞詈笠粋€(gè)成員的后面,不能加逗號(hào)
舉例來(lái)說(shuō),以下就是合格的JSON對(duì)象:
["one", "two", "three"]
{ "one": 1, "two": 2, "three": 3 }
{"names": ["張三", "李四"] }
[ { "name": "張三"}, {"name": "李四"} ]

window.JSON是瀏覽器內(nèi)置對(duì)象其中JSON.parse()表示把字符串解析為JSON對(duì)象,而JSON.stringify()表示將JSON對(duì)象解析為字符串

11.如何把JSON 格式的字符串轉(zhuǎn)換為對(duì)象?如何把對(duì)象轉(zhuǎn)換為 JSON 格式的字符串?.

答:比如var str = {name:"jirengu",age:2} 然后,JSON.stringify(str),再來(lái)就是,JSON.parse(JSON.stringify(str)).

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 0、對(duì)于 HTTP 協(xié)議而言,HTML、CSS、JS、JSON 的本質(zhì)都是什么? HTML就是符合HTML語(yǔ)法的字...
    怎么昵稱閱讀 1,690評(píng)論 0 3
  • 1.使用數(shù)組拼接出如下字符串 };```function getTpl(data){var arr = "";fo...
    湖衣閱讀 404評(píng)論 0 0
  • 冰淇淋可以隨身攜帶了?不怕融化了?腦洞有點(diǎn)大?。?! 紐約布魯克林有一款冰淇淋叫Gastronaut,G(給)ast...
    腦洞無(wú)極限閱讀 667評(píng)論 5 0
  • 《紅樓夢(mèng)》中夫妻之間的感情很微妙。 賈蓉和秦可卿夫妻在書中沒(méi)有直接說(shuō)過(guò)話,女方死后,賈珍這個(gè)公公哭的淚人一般,...
    九九弱水三千閱讀 2,273評(píng)論 11 12
  • 當(dāng)我們欲火焚身,互相撕扯著對(duì)方衣服的時(shí)候我害怕了,想到我根本不能娶她,甚至我根本沒(méi)有非常喜歡她,我沒(méi)有能進(jìn)入她...
    ImasingerWhoru閱讀 421評(píng)論 0 1

友情鏈接更多精彩內(nèi)容