JS基礎-Math數組Date
本篇講解了js的基礎math陣列和date的相關知識。
一.Math
1、寫一個函數,傳回從min到max之間的隨機整數,包括min不包括max
//不包含最大数 function getNum(min,max){ //包含最小值,随机最小值与最大值之间的整数且不包含最大值 console.log(min+Math.floor(Math.random()*(max-min))) } getNum(10,15)
2、寫一個函數,傳回從min都max之間的隨機整數,包括min包含max
//也包含最大數
function getNum2(min,max){ //包含最小值,随机最小值与最大值之间的整数且包含最大值 console.log(min+Math.floor(Math.random()*(max+1-min))) } getNum2(10,15)
3、寫一個函數,產生一個長度為n 的隨機字串,字串字元的取值範圍包括0到9,a到z,A到Z。
function getRandStr(len){ //补全函数 var str1='' var str = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; for(var i=0;i<len;i++){ var ss=parseInt(Math.random()*str.length); str1 += str[ss]; } return str1 } var str = getRandStr(10); // 例:0a3iJiRZap console.log(str);
4、寫一個函數,產生一個隨機IP 位址,一個合法的IP 位址為0.0.0.0~255.255.255.255
function getRandIP(){ //补全 var ip='' for (var i=0; i<4; i++){ var str=Math.floor(Math.random()*256); ip += str; // 3个点是4个数 if( i<3 ){ ip += "."; } } return ip; }var ip = getRandIP()console.log(ip) // 例:10.234.121.45
5、寫一個函數,產生一個隨機顏色字符串,合法的顏色為#000000~ #ffffff
function getRandColor(){ var str = "0123456789abcdef"; var strlen = str.length; var colorstr = "#"; for(var i = 0; i < 6; i++){ var index = Math.floor(Math.random()*strlen); colorstr += str[strlen]; } return colorstr } var color = getRandColor() console.log(color) // 例:#3e2f1b
二.數組
1、數組方法裡push、pop、shift、unshift、join、splice分別是什麼作用?用splice函數分別實作push、pop、shift、unshift方法
push()、pop()和unshift()、shift()這兩組同為對陣列的操作,並且會改變陣列的本身的長度及內容。
不同的是 push()、pop() 是從陣列的尾部進行增刪,unshift()、shift() 是從陣列的頭部進行增刪。
splice() 方法向/從陣列中新增/刪除項目,然後傳回已刪除的項目。此方法會改變原始數組。
join() 方法用來把陣列中的所有元素放入一個字串。元素是透過指定的分隔符號進行分隔的。
//splice函数分别实现push、pop、shift、unshift方法//例子: var arr = [1,2,3,4,5] //push arr.splice(arr.length,0,6); //位置,要删除元素的个数,要添加到数组的元素 console.log(arr);//[1,2,3,4,5,6] console.log(arr.length) //pop arr.splice(arr.length-1,1) console.log(arr);//[1,2,3,4,5] //shift arr.splice(0,1); console.log(arr);//[2,3,4,5] //unshift arr.splice(0,0,1); console.log(arr);//[1,2,3,4,5]
2、寫一個函數,操作數組,數組中的每一項變成原來的平方,在原始數組上操作
function squareArr(arr){ for(var i = 0; i < arr.length; i++ ){ arr[i] *= arr[i] } return arr; } var arr = [2, 4, 6] squareArr(arr) console.log(arr) // [4, 16, 36]
3、寫一個函數,操作數組,返回一個新數組,新數組只包含正數,原始數組不變
function filterPositive(arr){ var newArr = []; for(var i = 0; i < arr.length; i++){ if(typeof(arr[i]) === "number" && arr[i] > 0){ newArr.push(arr[i]); } } return newArr; } var arr = [3, -1, 2, '饥人谷', true] var newArr = filterPositive(arr) console.log(newArr) //[3, 2]
三.Date
1、寫一個函數getChIntv,取得從目前時間到指定日期的間隔時間
function getChIntv(s) { //时间=指定时间-当前时间 var time = Math.abs(Date.parse(s) - Date.now()); //天数=时间/天的毫秒 var days = parseInt(time/(1000*60*60*24)); //几小时=时间%天的毫秒/一小时毫秒 var hours = parseInt((time%(1000*60*60*24))/(1000*60*60)); //几分钟=时间%天的毫秒/一小时毫秒/一分钟毫秒 var minutes = parseInt(((time%(1000*60*60*24))%(1000*60*60))/(1000*60)); //几秒=时间%天的毫秒/一小时毫秒/一分钟毫秒/一秒毫秒 var seconds = parseInt(((time%(1000*60*60*24))%(1000*60*60))%(1000*60)/1000); return days + '天' + hours + '小时' + minutes + '分钟' + seconds+ '秒' } var str = getChIntv('2017-7-01'); console.log(str);
2、把hh-mm-dd格式數字日期改成中文日期
function getChsDate(s) { var arr = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三' , '十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四', '二十五','二十六','二十七','二十八','二十九','三十','三十一'] //字符串拆成数组 var time = s.split('-'); // 输出字符串就行 var year = time[0]; var month = time[1]; var day = time[2]; var newYear = arr[year[0]]+arr[year[1]]+arr[year[2]]; var newMonth = arr[parseInt(month)]; var newDay = arr[parseInt(day)]; return newYear+"年"+newMonth+"月"+newDay+"日"; } var str = getChsDate('2017-06-30'); 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 msec=new Date() // getTime()返回距 1970 年 1 月 1 日之间的毫秒数 var nowTime=msec.getTime() var sec=(nowTime-time)/1000 if(sec<60){ return '刚刚' }else if(sec>=60&&sec<3600){ return '三分钟前' }else if(sec>=3600&&sec<8*3600){ return '8小时前' }else if(sec>=24*3600&&sec<24*3600*30){ return '3天前' }else if(sec>=24*3600*30&&sec<24*3600*30*12){ return '2个月前' }else if(sec>=24*3600*30*12){ return '8年前' } } var str = friendlyDate( '1484286699422' ) var str2 = friendlyDate('1483941245793') console.log(str) //2个月前 console.log(str2) //2个月前
本篇對js基礎相關知識進行的相關的講解,更多知識請關注php中文網。
相關推薦:
以上是JS基礎-Math數組Date的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
