- 使用数组拼接出如下字符串
var prod = {
name: '女装',
styles: ['短款', '冬季', '春装']
};
function getTpl(data){
var arr = new Array();
arr[0] = '<dl class="product">'
arr[1] = ' <dt>' + prod.name + '</dt>'
for(i=0;i<data.styles.length;i++){
arr[i+2]=' <dd>' + data.styles[i] + '</dd>'
}
arr.push('</dl>')
return arr.join('\n')
}
var result = getTpl(prod);
console.log(result)
//输出
<dl class="product">
<dt>女装</dt>
<dd>短款</dd>
<dd>冬季</dd>
<dd>春装</dd>
</dl>
- 写出两种以上声明多行字符串的方法
var longString = "Long \n\ //每一行后加反斜杠\ 原来写在一行的字符串,可以分成多行,效果与写在同一行完全一样
long \n\
long \n\
string";
console.log(longString)
//输出为
"Long
long
long
string"
var longString = "Long \n"+ //连接运算符(+)可以连接多个单行字符串,用来模拟多行字符串。
"long \n"+
"long \n"+
"string";
console.log(longString)
//输出为
"Long
long
long
string"
- 补全如下代码,让输出结果为字符串: hello\饥人谷
var str = 'hello\\\\饥人谷' //一个字符串中的反斜杠 需要反斜杠前再加一个反斜杠,用来对自身转义,所以有四个反斜杠
console.log(str)
- 以下代码输出什么?为什么
var str = 'jirengu\nruoyu'
console.log(str.length)
//输出为13
"jirengu //转行符也占一个字符,jirengu后有一个空格
ruoyu"
- 写一个函数,判断一个字符串是回文字符串,如 abcdcba是回文字符串, abcdcbb不是
var a = 'abcdcba'
var b = 'abcdefg'
var c = 'abcdecba'
function isPalindrome(str){
var arr = str.split('')
for(i=0;i<arr.length;i++){
if(arr[i]!==arr[arr.length-1-i]){
return false
}
}
return true
}
console.log(isPalindrome(a))
console.log(isPalindrome(b))
console.log(isPalindrome(c))
- 写一个函数,统计字符串里出现出现频率最多的字符
// 写一个函数,统计字符串里出现出现频率最多的字符
var str = 'lsakdhlsahflkasjdlkxcnkahloweiuqwokjdsk'
function find(str){
var list = {}
for(i=0;i<str.length;i++){
if(list[str[i]]){
list[str[i]]++
}else{
list[str[i]]=1
}
}
// console.log(list)
var inc = str[0]
for(key in list){
if(list[key]>list[inc]){
inc = key
}
}
console.log('最大值是'+'\"'+inc+'\",'+' 出现次数 '+ list[inc])
}
find(str)
- 写一个camelize函数,把my-short-string形式的字符串转化成myShortString形式的字符串,如
function camelize(str){
var a = []
var arr = []
a = str.split('-')
for(i=1;i<a.length;i++){
arr[i-1]=a[i].charAt(0).toUpperCase()+a[i].slice(1);
}
arr.unshift(a[0])
return arr.join('')
}
console.log(camelize("background-color"))// == 'backgroundColor'
console.log(camelize("list-style-image")) //== 'listStyleImage'
- 写一个 ucFirst函数,返回第一个字母为大写的字符 (***)
function ucFirst(str){
var first = str.charAt(0).toUpperCase()
var other = str.slice(1)
return console.log(first + other)
}
ucFirst("hunger") == "Hunger"
- 写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...,如
function truncate(str,maxlength){
if(str.length > maxlength){
return str.slice(0,maxlength)+ '...'
}else{
return str
}
}
console.log(truncate("hello, this is hunger valley,", 10))
console.log(truncate("hello world", 20))
// truncate("hello, this is hunger valley,", 10)) == "hello, thi...";
// truncate("hello world", 20)) == "hello world"
- 什么是 json?什么是 json 对象?什么是 json 对象字面量?什么是 JSON内置对象?
- JSON(JavaScript ObjectNotation,JavaScript对象表示法),是js的一个严格的子集,利用了js中的一些模式来表示结构化数据
- JSON对象作为一种复杂数据类型,表示一组无序的键值对。而每个键值对中的值可以是简单值也可以是复杂数据类型的值
//js中的对象
var person = {
name : "jirengu" ,
age : 28
};
//JSON中
{
"name" : "jirengu", //字符串和键名要在双引号里
"age" : 28 //最后一行不能加逗号
}
- {花括号内的内容就是json对象字面量 }
- ES5定义了一个原生的JSON对象,可以用来将对象序列化为JSON字符串或者将JSON数据解析为JavaScript对象。JSON.stringify()和JSON.parse()方法分别来实现上述两项功能
- 如何把JSON 格式的字符串转换为对象?如何把对象转换为 JSON 格式的字符串?
前一个用JSON.parse()方法,后一个用方法JSON.stringify()
var person = {
'name' : 'jirengu' ,
'age' : 28
};
console.log(person)
console.log(JSON.stringify(person))
console.log(JSON.parse(JSON.stringify(person)))