美文网首页
进阶-任务5

进阶-任务5

作者: nicole914 | 来源:发表于2017-03-12 17:25 被阅读0次

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

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

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

// 使用反斜杠
var longString = "Long \
long \
long \
string";
// 使用+号连接
var longString = 'Long '
  + 'long '
  + 'long '
  + 'string';
// 利用多行注释
(function () { /*
line 1
line 2
line 3
*/}).toString().split('\n').slice(1,-1).join('\n');

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

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

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

输出13
因为\n代表换行符,n前加反斜杠\用来转义,\n算作一个字符

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

var str1 = 'abcdcba';
var str2 = 'abcdcbb';
function isPalindrome(str) {
    return str === str.split('').reverse().join('');
}
console.log(isPalindrome(str1));
console.log(isPalindrome(str2));

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

var str = 'adfl askdj flkjlaksdjf lkasjdfkwj';
str.replace(/[^a-z]/gi,'');
var dict = {};
for (var i=0;i<str.length;i++) {
    if (dict[str[i]]) {
        ++dict[str[i]];
    }else {
        dict[str[i]] = 1;
    }
}

var count = 0;
var max;
for (var key in dict) {
    if (dict[key] > count) {
        max = key;
        count = dict[key];
    }
}
console.log(count, max);

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

function camelize(str) {
    return str.replace(/-/g,'');
}

function camelize(str) {
    return str.split('-').join('');
}

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

function ucFirst(str) {
    return str[0].toUpperCase()+str.substring(1);
}

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

function truncate(str, maxlength) {
    if (maxlength > 0 && str.length > maxlength) {
        return str.substr(0,maxlength) + '...';
    }
    return str;
}

10.什么是 json?什么是 json 对象?什么是 json 对象字面量?什么是 JSON内置对象?

  • JSON格式(JavaScript Object Notation的缩写)是一种用于数据交换的文本格式,2001年由Douglas Crockford提出,目的是取代繁琐笨重的XML格式。相比XML格式,JSON格式有两个显著的优点:书写简单,一目了然;符合JavaScript原生语法,可以由解释引擎直接处理,不用另外添加解析代码。所以,JSON迅速被接受,已经成为各大网站交换数据的标准格式,并被写入ECMAScript 5,成为标准的一部分。
  • 每个JSON对象,就是一个值。要么是简单类型的值,要么是复合类型的值。JSON对值的类型和格式有严格的规定:
    复合类型的值只能是数组或对象,不能是函数、正则表达式对象、日期对象;
    简单类型的值只有四种:字符串、数值(必须以十进制表示)、布尔值和null(不能使用NaN, Infinity, -Infinity和undefined);
    字符串必须使用双引号表示,不能使用单引号;
    对象的键名必须放在双引号里面;
    数组或对象最后一个成员的后面,不能加逗号;
  • json 对象字面量就是json格式的JavaScript对象字面量,具有以下形式:
var json1 = {"name": "Byron", "age": "24"}
  • JSON内置对象
    ES5新增的JSON对象,用来处理JSON格式数据。它有两个方法:JSON.stringify()JSON.parse()

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

  • 把JSON 格式的字符串转换为对象:JSON.parse()
var o = JSON.parse('{"name": "张三"}');
o.name // 张三
  • 把对象转换为 JSON 格式的字符串: JSON.stringify()
JSON.stringify({ name: "张三" })
// '{"name":"张三"}'

相关文章

  • 进阶任务5

    JSON(Java Script Object Notation )是一种轻量级的数据交换格式。JSON对值的类型...

  • 进阶任务5

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

  • 进阶任务5

    1、使用数组拼接出如下字符串 2、写出两种以上声明多行字符串的方法 方法1 利用行尾转义'/' 方法2 利用加号+...

  • 进阶任务-5

    0. 对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 对于http 协议而言这些语言...

  • 进阶任务5

    1.使用数组拼接出如下字符串### 2.写出两种以上声明多行字符串的方法### 例如: 3.补全如下代码,让输出结...

  • 进阶-任务5

    1.使用数组拼接出如下字符串 2.写出两种以上声明多行字符串的方法 3.补全如下代码,让输出结果为字符串: hel...

  • 进阶任务5

    1、使用数组拼接出如下字符串 2、写出两种以上声明多行字符串的方法 3、补全如下代码,让输出结果为字符串: hel...

  • 关于时间管理的100条干货(下)

    Part5【进阶时间管理修炼的十个关键词】 关键词一:多任务处理 61.多任务处理让个人效率提升5-10倍 这里的...

  • Swift多线程:GCD进阶,单例、信号量、任务组

    Swift多线程:GCD进阶,单例、信号量、任务组 Swift多线程:GCD进阶,单例、信号量、任务组

  • 进阶任务5(主线任务):字符串与JSON

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

网友评论

      本文标题:进阶-任务5

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