1、使用数组拼接出如下字符串
var product = {
name: '女装',
styles: ['短款', '冬季', '春装']
};
function getTpl(product) {
var str = '<dl>';
str += ' <dt>' + product.name + '</dt>';
for(var i = 0; i < product.styles.length; i++) {
str += ' <dd>' + product.styles[i] + '</dd>';
}
str += ' </dl>';
return str;
}
console.log(getTpl(product));
<dl class="product">
<dt>女装</dt>
<dd>短款</dd>
<dd>冬季</dd>
<dd>春装</dd>
</dl>
2、写出两种以上声明多行字符串的方法
字符串默认只能写在一行内,分成多行将会报错。
- 如果长字符串必须分成多行,可以在每一行的尾部使用反斜杠
var longString = "Long \
long \
long \
string";
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')
// "line 1 line 2 line 3"
3、补全如下代码,让输出结果为字符串: hello\饥人谷
var str = "hello\\\\饥人谷";
console.log(str);```
##4、以下代码输出什么?为什么
var str = 'jirengu\nruoyu';
console.log(str.length);```
输出13,因为\n算作一个字符。
5、写一个函数,判断一个字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
var a = "abcdedcba";
function isText(str){
var newStr = str.split("").reverse().join("");
if(newStr === str){
return true;
}
else{
return false;
}
}
console.log(isText(a));```
##6、写一个函数,统计字符串里出现出现频率最多的字符
var str = "znmkaslkglkxznaskljhegtoidsaaad";
function getMostFreq(str){
var num = 1;
var max = 0;
var maxCh;
var arr = str.split("").sort();
for(var i=0;i<arr.length;i++){
if(arr[i+1]===arr[i]){
num++;
}
else{
num=1;
}
if(num>max){
max=num;
maxCh=arr[i];
}
}
return ("最多字符为"+maxCh+"\n出现次数为"+max);
}
console.log(getMostFreq(str));```
7、写一个camelize函数,把my-short-string形式的字符串转化成myShortString形式的字符串
var str = "my-short-string";
function camelize(str){
var newStr="";
var a = str.split("-");
for(var i=1;i<a.length;i++){
newStr += a[i].replace(a[i][0],a[i][0].toUpperCase());
}
return(a[0]+newStr);
}
console.log(camelize(str));```
##8、写一个 ucFirst函数,返回第一个字母为大写的字符
var str = "hunger";
function ucFirst(str){
return(str.replace(str[0],str[0].toUpperCase()));
}
console.log(ucFirst(str));```
9、写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...
var str = "hungerdsagregcbsgaewre";
function truncate(str,maxlength){
if(str.length <= maxlength){
return str;
}
else{
return (str.substr(0,maxlength-1)+"...");
}
}
console.log(truncate(str,10));
10、什么是 json?什么是 json 语言?JSON 语言如何表示对象?window.JSON 是什么?
- 什么是 json
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(网络传输速度)。 - json 语言
用于表示JSON数据格式的遵循一定语法的语言。 - JSON 语言如何表示对象
对象是一个无序的“名称/值对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“名称/值对”之间使用“,”(逗号)分隔。 - window.JSON 是什么
window.JSON 是JSON对象,JSON对象主要有两个『静态』函数
parse:把字符串转化为JSON对象
stringify:把JSON对象转化为字符串(出人意料的不叫toString,因为不是实例方法)
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));