进阶5

作者: 取个名字都不行 | 来源:发表于2017-10-12 12:03 被阅读0次

1.对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么?

都是字符串。浏览器根据相应请求头中的Content-Type以对应的语法解析这些字符串,再分别渲染执行。

2.使用数组拼接出如下字符串 ,其中styles数组里的个数不定

var prod = {
    name: '女装',
    styles: ['短款', '冬季', '春装']
};
function getTpl(data){
  var htstart = '<dl class=\"product\">';
  var htend = '</dl>';
  var htmid = '<dt>'+data.name+'</dt>';
  var pmid = '';
  for(var i = 0;i<data.styles.length;i++){
    pmid = pmid+'<dd>'+data.styles[i]+'</dd>';
    }
  var all = htstart + htmid + pmid +htend;
  return all;
}
var result = getTpl(prod);  //result为下面的字符串
console.log(result);

3.写出两种以上声明多行字符串的方法

var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde';
//方法1
var str1='abcdeabcdeabcdeancdeabc\
deabcdeabcdeancdeabcdeab\
cdeabcdeancdeabcdeabcdeabcdeancde';
console.log(str1);
//方法2
var str2='abcdeabcdeabcdeancdeabc'+
'deabcdeabcdeancdeabcdeab'+
'cdeabcdeancdeabcdeabcdeabcdeancde';
console.log(str2);

4.补全如下代码,让输出结果为字符串: hello\饥人谷

var str = 'hello\\\\饥人谷';
console.log(str);

5.以下代码输出什么?为什么

var str = 'jirengu\nruoyu';
console.log(str.length);
/*str.length指的是str字符串的长度,其中\n在字符串表示换行,所以只占一个字符长度
*/

6.写一个函数,判断一个字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是

var str = 'abcdcba';
var str1 = 'abcdcbb';
function judgment(ori){
  var newori = ori.split('').reverse().join('');
  console.log(newori==ori);
}
judgment(str);//true
judgment(str1);//false

7.写一个函数,统计字符串里出现出现频率最多的字符

function dis(ori){
  var dict={};
  var count = 0;
  var max;
  for(i=0;i<ori.length;i++){
    if(dict[ori[i]]){
    ++dict[ori[i]];
    }
    else{
    dict[ori[i]]=1;
    }
  }
 
  for(var key in dict){
    if(dict[key]>count){
    max=key;
    count = dict[key];
    }
  }
  return {cha:max,num:count};
 
}
var str = 'aaabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde';
console.log(dis(str));

8.写一个camelize函数,把my-short-string形式的字符串转化成myShortString形式的字符串,如


function camelize(ori){
   var arr = ori.split('-');
   for(i=0;i<arr.length;i++){
      if(i!==0){ 
        arr[i] = arr[i].replace(arr[i].charAt(0), arr[i].charAt(0).toUpperCase());
      }
   }
   var newarr = arr.join('');
   return newarr;
}
var str = 'list-style-image';
console.log(camelize(str));

9.写一个 ucFirst函数,返回第一个字母为大写的字符 (***)

var str ='hunger';
function ucFirst(ori){
 var st = ori.substr(0,1);
 var newori = ori.replace(st,st.toUpperCase());
  return newori;
}
console.log(ucFirst(str));

10.写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...

var str ='hello, this is hunger valley,';
var str1 = 'hello world';
function truncate(ori,num){
  if(ori.length>num){
  var fstr = ori.substr(0,num);
  var newori = fstr +'...';
    return newori;
  
  }else{
    return ori;
  }
  
}

console.log(truncate(str,10));
console.log(truncate(str1,20));

11.什么是 JSON格式数据?JSON格式数据如何表示对象?window.JSON 是什么?

JSON(JavaScript Object Notation)是一种由道格拉斯·克罗克福特构想设计、轻量级的数据交换语言,以文字为基础,且易于让人阅读。JOSN 是类对象字符串,是字符串,它不能被调用或者作为构造函数,除了它的两个方法属性,它本身并没有有趣的功能。JSON 由一对花括号包裹,里面的值以key: value形式存储,如:

{
"name":"dawang"
"sex":"male"
}

window.JSON 是一个对象,里面只包含两个方法parse()和stringify(),分别用于解析和转化 JSON 对象。

12.如何把JSON 格式的字符串转换为 JS 对象?如何把 JS对象转换为 JSON 格式的字符串?

parse:把字符串转化为JSON对象
stringify:把JSON对象转化为字符串

var str = {"name":"dawang","sex":"male"};
var newstr = JSON.stringify(str);
console.log(newstr);
var lstr = JSON.parse(newstr);
console.log(lstr);

相关文章

  • BAT面试算法进阶(6)- 最长回文子串(方法二)

    BAT面试算法进阶(5)- BAT面试算法进阶(5)- 最长回文子串(方法一)BAT面试算法进阶(4)- 无重复字...

  • BAT面试算法进阶(7)- 反转整数

    BAT面试算法进阶(6)- BAT面试算法进阶(6)-最长回文子串(方法二)BAT面试算法进阶(5)- BAT面试...

  • 进阶5

    对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 对于HTTP来讲,HTML、CSS、...

  • 进阶5

    0、对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 本质上都是符合HTML、CSS、...

  • 进阶5

    1.对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 都是字符串。浏览器根据相应请求头...

  • 进阶5

    对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 字符串浏览器根据相应请求头中的Con...

  • 进阶5

    0.对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 符合各自语法规则的字符串 1.使...

  • 进阶5

    对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 1.对于HTTP协议而言,html、...

  • 5-28/我在28天进阶写作班收获了什么

    5月5日我进入28天进阶写作班,在这段时间里我每天都很忙,每天都在坚持。我在28天进阶写作班收获了什么? ...

  • webpack进阶【6】: 分离css文件【mini-css-e

    webpack: 分离css文件 注意:本进阶在webpack进阶【5】的基础上进行总结。 一、为什么要分离出cs...

网友评论

      本文标题:进阶5

      本文链接:https://www.haomeiwen.com/subject/brsuyxtx.html