1、使用数组拼接出如下字符串 ,其中styles数组里的个数不定
<dl class="product"><dt>女装</dt><dd>短款</dd><dd>冬季</dd><dd>春装</dd></dl>
<script>
var prod = {
name: '女装',
styles: ['短款', '冬季', '春装']
};
function getTplStr(data){
var arr = [],i=0;
for(var key in data){
if(typeof data[key] === 'number' || typeof data[key] === 'string' || typeof data[key] === 'boolean'
|| data[key] === undefined || data[key] === null){
arr[i] = data[key];
i++;
}else{
for(var j=0;j<data[key].length;j++){
arr[i+j] = data[key][j];
}
}
}
document.write('<dl class="product">' + '<dt>' + arr[0] + '</dt>');
for(i=1;i<arr.length;i++){
document.write('<dd>' + arr[i] + '</dd>');
}
document.write('</dl>');
};
var result = getTplStr(prod); //result为下面的字符串
<dl class="product"><dt>女装</dt><dd>短款</dd<dd>冬季</dd><dd>春装</dd></dl>
2.写出两种以上声明多行字符串的方法
例如:
var str = 'abcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancdeabcdeabcdeabcdeancde'
第一种方法,换行处加' \ ':
var str = 'abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\
abcde\';
第二种方法,使用连接符' + ':
var str = 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde'
+ 'abcde';
3.补全如下代码,让输出结果为字符串: hello\饥人谷
var str = 'hello\\\\饥人谷' //补全代码
console.log(str)
4.以下代码输出什么?为什么
var str = 'jirengu\nruoyu'
console.log(str.length)
以上代码输出的str的长度为13,因为' \n '是换行符,不计入长度里面。
5.写一个函数,判断一个字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
var str = 'abcdcba';
function reverseStr(str) {
var newStr;
newStr = str.split('').reverse().join('');
if(newStr === str){
console.log("这是一个回文字符串");
}else {
console.log('这不是一个回文字符串');
}
}
reverseStr(str);
6.写一个函数,统计字符串里出现出现频率最多的字符
var str = 'abcdabcaba';
function calcLetterOfLargestNumber(str) {
var arr = [];
arr = str.split('');
var max = 0,compareValue=0;
var letter;
for(var i=0;i<arr.length;i++){
if(i === 0){
for(var j=0;j<arr.length;j++){
if(arr[i] === arr[j]){
max++;
}
}
letter = arr[i];
}else {
for(j=0;j<arr.length;j++){
if(arr[i] === arr[j]){
compareValue++;
}
}
if(compareValue >= max){
letter = arr[i];
}
max = Math.max(max,compareValue);
compareValue = 0;
}
}
console.log('出现频率最高的字符是' + ' ' + letter);
}
calcLetterOfLargestNumber(str);
7.写一个camelize函数,把my-short-string形式的字符串转化成myShortString形式的字符串,如
camelize("background-color") == 'backgroundColor'
camelize("list-style-image") == 'listStyleImage'
函数代码如下:
var str = 'my-short-string';
function camelize(str) {
var arr = [],
newstr;
arr = str.split('');
for(var i=0;i<arr.length;i++){
if(arr[i] === '-'){
arr[i+1] = arr[i+1].toUpperCase();
}
}
newstr = arr.join('');
console.log(newstr);
}
camelize(str);
camelize("background-color");
camelize("list-style-image");
8.写一个 ucFirst函数,返回第一个字母为大写的字符 (***)
var str = 'hunger';
function ucFirst(str) {
var arr = [],
newstr;
arr = str.split('');
arr[0] = arr[0].toUpperCase();
newstr = arr.toString().replace(/,/g,'');
return newstr;
}
console.log(ucFirst(str));
9.写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...,如
truncate("hello, this is hunger valley,", 10) == "hello, thi...";
truncate("hello world", 20) == "hello world"
代码如下:
function truncate(str,maxlength) {
var arr = [],
newstr;
arr = str.split('');
if(arr.length > maxlength){
newstr = str.substr(0,maxlength) + '...';
return newstr;
}else{
return str;
}
}
console.log(truncate("hello, this is hunger valley,", 10));
console.log(truncate("hello world", 20));
10.什么是 JSON格式数据?JSON格式数据如何表示对象?window.JSON 是什么?
- JSON格式数据是一种轻量级的数据交换格式,它是javascript的一个子集,JSON采用完全独立于语言的文本格式,但也采用了类似于C语言家族的习惯。这些特性使得它成为了理想的数据交换语言,它不仅易于人类的读写,还易于机器解析和网络传输。
- JSON数据的书写格式是: 名称/值对,名称在前,值对在后,并且都分别用双引号包起来,两者之间使用冒号分隔。然后每一个名称/值对,也就是键值,使用逗号分隔。
- 判断浏览器是否支持JSON,例如:
if(window.json){
statement;
}else{
statement;
}
11.如何把JSON 格式的字符串转换为 JS 对象?如何把 JS对象转换为 JSON 格式的字符串?
JSON.parse()把JSON 格式的字符串转换为 JS 对象,JSON.stringify()把 JS对象转换为 JSON 格式的字符串。
例如:
var obj = {
"name": "1",
"age": "10"
};
var jsonStr = JSON.stringify(obj); //把 JS对象转换为 JSON 格式的字符串
var jsonObj = JSON.parse(jsonStr); //把JSON 格式的字符串转换为 JS 对象