进阶任务5-字符串与JSON

1、使用数组拼接出如下字符串:

var prod = {
    name: '女装',
    styles: ['短款', '冬季', '春装']
};
function getTpl(data){
//todo...
};
var result = getTplStr(prod);  //result为下面的字符串

<dl class="product">
    <dt>女装</dt>
    <dd>短款</dd>
    <dd>冬季</dd>
    <dd>春装</dd>
</dl>
<script>
    var prod = {
    name: '女装',
    season: '冬季',
    styles: ['短款', '冬季', '春装']
  };
  function getTpl(data) {
    var str = '<dl class="product">';
    for (var key in data) {
      if(typeof data[key] === 'number'
        || typeof data[key] === 'string'
        || typeof data[key] === 'boolean'
        || data[key] === undefined
        || data[key] === null) {
        str += ('<dt>' + data[key] + '</dt>')
      } else {
        for (var i = 0; i < data[key].length; i++) {
          str += ('<dd>' + data[key][i] + '</dd>')
        }
      }
    }
    str += '</dl>';
    return str;
  }
  var result = getTpl(prod)
  console.log(result);
</script>

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

例如:

var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
这段字符串很长,如何多行优雅的显示

<script>
  var str = 'abcdeabcdeabcdeancde\
abcdeabcdeabcdeancde\
abcdeabcdeabcdeancde\
abcdeabcdeabcdeancd '
  var str2 = 'abcdeabcdeabcdeancde'
    + 'abcdeabcdeabcdeancde'
    + 'abcdeabcdeabcdeancde'
    + 'abcdeabcdeabcdeancde';
  console.log(str, str2)  
</script>

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

var str = //补全代码
console.log(str)

    var str3 = 'hello\\' + '\\饥人谷'//补全代码
    var str4 = 'hello\\\\饥人谷'//补全代码
    console.log(str3)
    console.log(str4)

4、以下代码输出什么?为什么

    var str = 'jirengu\nruoyu' //  '\n'为转义符'换行',占一个字符长度
    console.log(str.length)    //    13

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

<script>
  var str1 = 'abcdcba'
  function detecBackWriting(str) {
    var newstr = str.split('').reverse().join('');
    return newstr
  }
  var str2 = detecBackWriting(str1)
  if (str2 == str1) {
    console.log('字符串为回文')
  }
</script>

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

<script>
  // 写一个函数,得到一个字符串里出现频率最高的一个字符
  var str = 'hello world, jirengu haha hoho hoho lol'
  var dict = {}
  for (var i = 0; i < str.length; i++) {
    if (dict[str[i]]) {
      ++dict[str[i]]
    } else {
      dict[str[i]] = 1
    }
  }
  console.log(dict)
  var count = 0
  var maxValue
  for (key in dict) {
    if (dict[key] > count) {
      maxValue = key
      count = dict[key]
    }
  }
  console.log(maxValue, count)
</script>

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

camelize("background-color") == 'backgroundColor'
camelize("list-style-image") == 'listStyleImage'
<script>
  var str1 = 'background-color'
  var str2 = 'list-style-image'
  function fn(str) {
    var arry = str.split('-');
    for (var i = 1; i < arry.length; i++) {
      arry[i] = arry[i][0].toUpperCase() + arry[i].substr(1);
    }
    str = arry.join('');
    return str;
  }
  console.log(fn(str1))
  console.log(fn(str2))
</script>

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

ucFirst("hunger") == "Hunger"

<script>
  var str1 = 'hunger'
  function ucFirst(str) {
    var arry = str[0].toUpperCase() + str.substr(1);
    return arry
  }
  console.log(ucFirst(str1))
</script>

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

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

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

  function truncat(str1, str2) {
    var newstr
    if (str1.length > str2) {
      newstr = str1.substr(0, str2) + '...'
    } else {
      newstr = str1
    }
    return newstr
  }
  console.log(truncat("hello, this is hunger valley,", 10))
  console.log(truncat("hello world", 20))

</script>

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

  • 什么是 JSON格式数据
    JSON格式数据即JavaScript Object Notation数据,是一种用于数据交换的文本格式;
    简单说,每个JSON对象,就是一个值。要么是简单类型的值,要么是复合类型的值,但是只能是一个值,不能是两个或更多的值。这就是说,每个JSON文档只能包含一个值。
  • JSON格式数据如何表示对象?
    JSON对值的类型和格式有严格的规定。
  1. 复合类型的值只能是数组或对象,不能是函数、正则表达式对象、日期对象。
  2. 简单类型的值只有四种:字符串、数值(必须以十进制表示)、布尔值和null(不能使用NaN, Infinity, Infinity和undefined)。
  3. 字符串必须使用双引号表示,不能使用单引号。
  4. 对象的键名必须放在双引号里面。
  5. 数组或对象最后一个成员的后面,不能加逗号。
    以下是合格的JSON值:
["one", "two", "three"]
{ "one": 1, "two": 2, "three": 3 }
{"names": ["张三", "李四"] }
[ { "name": "张三"}, {"name": "李四"} ]

以下是不合格的JSON值:

{ name: "张三", 'age': 32 }  // 属性名必须使用双引号
[32, 64, 128, 0xFFF] // 不能使用十六进制值
{ "name": "张三", "age": undefined } // 不能使用undefined
{ "name": "张三",
  "birthday": new Date('Fri, 26 Aug 2011 07:13:10 GMT'),
  "getName": function() {
      return this.name;
  }
} // 不能使用函数和日期对象

需要注意的是,空数组和空对象都是合格的JSON值,null本身也是一个合格的JSON值。

  • window.JSON 是什么?
    window.JSON是指通过将如下代码放在script的开始位置,达到在低版本不兼容JSON的浏览器中使用JSON对象的作用
if (!window.JSON) {
  window.JSON = {
    parse: function(sJSON) { return eval('(' + sJSON + ')'); },
    stringify: (function () {
      var toString = Object.prototype.toString;
      var isArray = Array.isArray || function (a) { return toString.call(a) === '[object Array]'; };
      var escMap = {'"': '\\"', '\\': '\\\\', '\b': '\\b', '\f': '\\f', '\n': '\\n', '\r': '\\r', '\t': '\\t'};
      var escFunc = function (m) { return escMap[m] || '\\u' + (m.charCodeAt(0) + 0x10000).toString(16).substr(1); };
      var escRE = /[\\"\u0000-\u001F\u2028\u2029]/g;
      return function stringify(value) {
        if (value == null) {
          return 'null';
        } else if (typeof value === 'number') {
          return isFinite(value) ? value.toString() : 'null';
        } else if (typeof value === 'boolean') {
          return value.toString();
        } else if (typeof value === 'object') {
          if (typeof value.toJSON === 'function') {
            return stringify(value.toJSON());
          } else if (isArray(value)) {
            var res = '[';
            for (var i = 0; i < value.length; i++)
              res += (i ? ', ' : '') + stringify(value[i]);
            return res + ']';
          } else if (toString.call(value) === '[object Object]') {
            var tmp = [];
            for (var k in value) {
              if (value.hasOwnProperty(k))
                tmp.push(stringify(k) + ': ' + stringify(value[k]));
            }
            return '{' + tmp.join(', ') + '}';
          }
        }
        return '"' + value.toString().replace(escRE, escFunc) + '"';
      };
    })()
  };
}

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

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

var json = {
  "name": "Byron",
  "age": 24
};

var json_str = JSON.stringify(json);
console.log(json_str);
console.log(JSON.parse(json_str)); 

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,233评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,013评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,030评论 0 241
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,827评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,221评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,542评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,814评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,513评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,225评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,497评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,998评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,342评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,986评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,812评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,560评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,461评论 2 266

推荐阅读更多精彩内容