使用数组拼接出如下字符串 ,其中styles数组里的个数不定
var prod = {
name: '女装',
styles: ['短款', '冬季', '春装']
};
function getTplStr(data){
var arr = ['<dl class="product">', '<dt>' + data.name + '</dt>'];
for(var i = 0; i < data.styles.length; i++) {
arr.push('<dd>' + data.styles[i] + '</dd>');
}
arr.push('</dl>');
return arr.join('');
};
var result = getTplStr(prod); //result为下面的字符串
<dl class="product"><dt>女装</dt><dd>短款</dd><dd>冬季</dd><dd>春装</dd></dl>
写出两种以上声明多行字符串的方法
// 如果长字符串必须分成多行,可以在每一行的尾部使用反斜杠。
// 注:反斜杠后不能出现空格
var str = 'hello \
world\
!';
//输出:"hello world !"
var str = 'hello '
+ 'world'
+ '!';
//输出:"hello world!"
补全如下代码,让输出结果为字符串: hello\\饥人谷
var str = 'hello\\\\饥人谷'//补全代码
console.log(str)
以下代码输出什么?为什么
var str = 'jirengu\nruoyu'
console.log(str.length) // 13,"\n"为换行符,算一个字符
写一个函数,判断一个字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
var str1 = 'abcdcba',
str2 = 'abcdcbb';
function isSymmetrical(str) {
return str === str.split('').reverse().join('');
}
console.log(isSymmetrical(str1)); //true
console.log(isSymmetrical(str2)); //false
写一个函数,统计字符串里出现出现频率最多的字符
function findMaxChar(str) {
//创建字典,格式为:字符: 出现次数
var dict = {}; //字典
var maxNum = 0; //出现最多频率的次数
var maxChar = []; // 出现频率最多的字符组成的数组
for(i = 0; i < str.length; i++) {
var char = str[i];
if(dict[char]){
dict[char]++;
} else {
dict[char] = 1;
}
}
//找出字典属性值中的最大值
var arr = [];
for(var char in dict) {
arr.push(dict[char]);
}
maxNum = Math.max.apply(Math,arr);
// 找出最大值对应的字符串
for(var char in dict) {
if(dict[char] === maxNum){
maxChar.push(char);
}
}
return maxChar;
}
var str1 = 'mmmmmamba is a spirit';
var str2 = 'abcdef'
console.log(findMaxChar(str1).toString()); //m
console.log(findMaxChar(str2).toString()); //a,b,c,d,e,f
写一个camelize函数,把my-short-string形式的字符串转化成myShortString形式的字符串
function camelize(str) {
var arrSubStr = str.split('-');
for(var i = 1; i < arrSubStr.length; i++) {
arrSubStr[i] = arrSubStr[i][0].toUpperCase() + arrSubStr[i].slice(1);
}
return arrSubStr.join('');
}
console.log(camelize("background-color")); //backgroundColor
console.log(camelize("list-style-image")); //listStyleImage
写一个 ucFirst函数,返回第一个字母为大写的字符
function ucFirst(str) {
return str[0].toUpperCase() + str.slice(1);
}
console.log(ucFirst("hunger") == "Hunger") //true
写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...,
function truncate(str, num) {
if(str.length > num) {
return str.substr(0, num) + '...';
}
return str;
}
truncate("hello, this is hunger valley,", 10) == "hello, thi..."; // true
truncate("hello world", 20) == "hello world" //true
什么是 JSON格式数据?JSON格式数据如何表示对象?window.JSON 是什么
JSON(JavaScript Object Notation JavaScript对象表示法) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(网络传输速度)。
- JSON可以表示简单值,如字符串、数值、布尔值和null,也可以表示对象、数组。但不支持特殊值undefined。
- JSON不支持变量、函数。
表示对象:名称/值对,名称/值对组合中的名称写在前面(在双引号中),值对写在后面,中间用冒号隔开:
{"name": "Byron", "age": 24}
[
{"name": "Byron", "age": 24},
{"name": "Byron2", "age": 25}
]
window.JSON是浏览器内置对象,可用于判断浏览器是否兼容JSON的用法,例如IE8版本以上才内置支持JSON.parse方法。JSON对象内置了JSON.parse()、JSON.stringify()两种方法
如何把JSON 格式的字符串转换为 JS 对象?如何把 JS对象转换为 JSON 格式的字符串?
- JOSN.parse()方法用来把JSON字符串解析为原生的JavaScript值
- JSON.stringify()用来把JavaScript对象序列化为JSON字符串,在序列化过程中,值为undefined的任何属性都会被跳过,所有函数也会被忽略(数组中的函数被赋为null值)