美文网首页
字符串与JSON

字符串与JSON

作者: annynick | 来源:发表于2017-06-17 22:19 被阅读0次

    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>
    

    代码如下:

    var prod = {
        name: '女装',
        styles: ['短款', '冬季', '春装']
    };
    function getTpl(data){
        arr=[];
        arr.push('<dl class="product">');
        arr.push('<dt>'+data.name+'</dt>');
        for(var i=0;i<data.styles.length;i++){
            arr.push('<dd>'+data.styles[i]+'</dd>')
        }
        arr.push('</dl>');
        console.log(arr.join(""));
    }
     getTpl(prod);
    

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

    例如:

    var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
    

    这段字符串很长,如何多行优雅的显示

    代码如下:

    1. 使用转义字符\n
     var str1='abcdeabcde\nabcdeancdeabcdeabcdea\nbcdeancdeabcdeabcde\nabcdeancdeabcde\nabcdeabcdeancde'
    
    1. 使用转移字符\ 空格
     var str1='abcdeabcde\
     \nabcdeancdeabcdeabcdea\
     \nbcdeancdeabcdeabcde\
     \nabcdeancdeabcde\
      \nabcdeabcdeancde'
    

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

    var str = "hello\\\\饥人谷"//补全代码
    console.log(str)
    

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

    var str = 'jirengu\nruoyu'
    console.log(str.length)  \\13 因为\n是转义符,只占一个长度
    

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

    var str="abcdcba";
    function isReverse(str){
        return str.split('').reverse().join('')    
    }
     var result = isReverse(str);
     if(result===str){
         console.log(str+"是回文字符串")
     }else{
         console.log(str+"不是回文字符串")
     }
    

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

    var str="hello,everythone,this is my facebook";
    var dist={};
    for(var i=0;i<str.length;i++){
        if(dist[str[i]]){
            ++ dist[str[i]]
        }else{
            dist[str[i]]=1
        }
       
    }
     //console.log(dist)
     var num=0;
     var max
     for(key in dist){
         if(dist[key]>num){
             num = dist[key]
             max = key
         }
     }
     console.log(num,max)
    

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

    function cameLize(str){
        var arr = str.split('-');
        if (arr.length === 1) return str;
        for (var i=1;i<arr.length;i++){
            arr[i] = arr[i][0].toUpperCase().concat(arr[i].substring(1));
        }
        return arr.join('')
    }
    console.log(cameLize("my-short-string"));
    

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

    function ucFirst(str){
        return str[0].toUpperCase().concat(str.substr(1));
    }
    

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

    function truncate(str,maxlength){
            var str2;
            if(maxlength>=str.length) {
                str2= str
            }else{
                    str2 =  str.slice(0,maxlength)+'...';
                }
                return str2;
        }
    var s1=truncate("hello, this is hunger valley,", 10) 
    var s2=truncate("hello world", 2)
    console.log(s1)
    console.log(s2)
    

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

    • json(javascript object notation)的缩写是一种用于数据交换的文本格式,目的是取代繁琐的xml。具有书写简单,一目了然,符号
      javascript原生语法,可以由解释引擎直接处理,不用另外添加解析代码。所以,json迅速被接受,成为es5标准的一部分。
    • var json1 = {"name": "Nick", "age": "7"}
    • window.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 格式的字符串?

    var str = {name:"anny",
                      age:20}
        console.log(JSON.stringify(str))
        console.log(JSON.parse(JSON.stringify(str)))
    

    相关文章

      网友评论

          本文标题:字符串与JSON

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