1、写一个函数,返回从min到max之间的 随机整数,包括min不包括max
function random(min, max) {
return min + Math.floor(Math.random()*(max-min))
}
var arr = [];
for(var i=0; i<10; i++){
arr.push(random(min,max))
}
console.log(arr)
2、写一个函数,返回从min都max之间的 随机整数,包括min包括max
function random(min, max) {
return min + Math.floor(Math.random()*(max-min))
}
var arr = [];
for(var i=0; i<10; i++){
arr.push(random(min,max+1))
}
console.log(arr)
3、写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z。
function getRanStr(len) {
var dict = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHEIJKLMNOQPRSTUVWXYZ"
var str = ""
for(var i = 0; i < len; i++){
str += dict[Math.floor(Math.random()*62)]
}
return str
}
console.log(getRanStr(10))
4、写一个函数,生成一个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255
function getRandIP(){
var arr = []
for(var i = 0; i < 4; i++){
arr[i] = Math.floor(Math.random()*256)
var ip = arr.join('.')
}
return ip
}
console.log(getRandIP())
5、写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff
function getRandColor() {
var dict = '0123456789abcdef'
var str = ''
for(var i = 0; i < 6; i++){
str += dict[random(0,16)]
}
str = '#'+str
return str
}
console.log(getRandColor())
数组任务
1、数组方法里push、pop、shift、unshift、join、splice分别是什么作用?用 splice函数分别实现push、pop、shift、unshift方法
- push: 栈方法,在数组最后添加值,返回数组长度;
- pop: 栈方法,取出数组最后一个值,返回被删除的元素;
- shit: 队列方法,删除数组最前面的值,返回被删除的元素;
- unshift: 队列方法,在数组最前面添加一个或多个值,返回数组长度;
- join:以指定分隔符将数组的值链接成字符串,返回生成的新字符串,()内接受指定分隔符参数,若为空字符,则元素直接联结成字符串;
- JavaScript提供了一个splice方法用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数:1.开始索引;2.删除元素的位移;3.插入的新元素,当然也可以写多个。splice方法返回一个由删除元素组成的新数组,没有删除则返回空数组。
- 用 splice函数分别实现push、pop、shift、unshift方法:
1.push:
var arr = [1,2,3,6,7,9]
function spliceToPush(arr, elements) {
arr.splice(arr.length, 0, elements)
return arr
}
console.log(spliceToPush(arr, 'asd')) // [1, 2, 3, 6, 7, 9, "asd"]
2.pop:
var arr = [1, 2, 3]
function spliceToPop(arr) {
arr.splice(arr.length - 1,1)
return arr
}
console.log(spliceToPop(arr)) // [1, 2]
3.shit:
var arr = [1,2,3,4,5,6,7]
function spliceToShift(arr) {
arr.splice(0,1)
return arr
}
console.log(spliceToShift(arr)) // [2, 3, 4, 5, 6, 7]
4.unshit:
var arr = [1,2,3,4,5,6,7]
function spliceToUnshift(arr, elements) {
arr.splice(0, 0, elements)
return arr
}
console.log(spliceToUnshift(arr, 'asddsa')) // ["asddsa", 1, 2, 3, 4, 5, 6, 7]
2、写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作
var arr = [2, 4, 6]
function squareArr(arr){
var arr = []
for(var i= 0; i < arr.length; i++){
arr[i] = arr[i] * arr[i]
}
return arr
}
console.log(squareArr(arr)) // [4, 16, 36]
3、写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变
var arr = [3, -1, 2, '饥人谷', true]
function filterPositive(arr){
var newArr = []
for(var i = 0; i < arr.length; i++ ){
if (typeof arr[i] === 'number') {
if (arr[i] > 0) [
newArr.push(arr[i])
]
}
}
return newArr
}
var newArr = filterPositive(arr)
console.log(newArr)//[3,2]
console.log(arr)//[3, -1, 2, '饥人谷', true]
Date 任务
1、 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间
function getChIntv(str){
var timeEnd = Date.parse(str);
var timeStart = new Date().getTime();
var offset = timeEnd - timeStart;
var days = parseInt(offset/(24*60*60*1000));
var hours = parseInt(offset%(24*60*60*1000)/(60*60*1000));
var minutes = parseInt(offset%(24*60*60*1000)%(60*60*1000)/(60*1000))
var seconds = parseInt(offset%(24*60*60*1000)%(60*60*1000)%(60*1000)/1000)
console.log(seconds);
var str ='距离'+str+'还有'+days+'天'+
hours +'小时' + minutes +'分'+ seconds +'秒';
return str;
}
var str = getChIntv("2017-02-08");
console.log(str);
2、把hh-mm-dd格式数字日期改成中文日期
function getChsDate(date1){
var chs ={"0":"零","1":"一","2":"二","3":"三","4":"四","5":"五","6":"六","7":"七","8":"八","9":"九","10":"十","11":"十一","12":"十二","13":"十三","14":"十四","15":"十五","16":"十六","17":"十七","18":"十八","19":"十九","20":"二十","21":"二十一","22":"二十二","23":"二十三","24":"二十四","25":"二十五","26":"二十一六","27":"二十七","28":"二十八","29":"二十九","30":"三十","31":"三十一"};
var str="";
var date2 =new Date(date1);
var year= date2.getFullYear().toString();
str+=chs[year[0]];
str+=chs[year[1]];
str+=chs[year[2]];
str+=chs[year[3]];
str +="年";
str +=chs[date2.getMonth()+1];
str +="月";
str +=chs[date2.getDate()];
str +="日";
return str;
}
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
3、写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数t,根据t的时间分别返回如下字符串:
刚刚( t 距当前时间不到1分钟时间间隔)
3分钟前 (t距当前时间大于等于1分钟,小于1小时)
8小时前 (t 距离当前时间大于等于1小时,小于24小时)
3天前 (t 距离当前时间大于等于24小时,小于30天)
2个月前 (t 距离当前时间大于等于30天小于12个月)
8年前 (t 距离当前时间大于等于12个月)
function friendlyDate(time){
var date=Date.now()-new Date(parseInt(time));
var str;
if(date<0){
str = "那是未来";
}else if(date<60*1000){
str = "刚刚";
}else if(date<(3600*1000)){
str =Math.floor(date/60/1000)+"分钟前";
}else if(date<(24*3600*1000)){
str =Math.floor(date/3600/1000)+"小时前";
}else if(date<(30.41*24*3600*1000)){
str =Math.floor(date/24/3600/1000) + "天前";
}else if(date<(365.24*24*3600*1000)){
str =Math.floor(date/30.41/24/3600/1000) + "月前";
}else if(date<(10000*365.24*24*3600*1000)){
str =Math.floor(date/365.24/24/3600/1000) + "年前";
}
return str;
}
var str = friendlyDate( '1484286699422' ) //1分钟前
console.log(str);
var str2 = friendlyDate('1483941245793') //4天前
console.log(str2);