js —— 純函數


//純函數 ---> 不對外界產生副作用的函數就叫純函

純函數:const sum = function(value1, value2) { return value1 + value2 }

*********************************
只要每次給定相同的輸入值,就一定會得到相同的輸出值: 例如傳入1與2,就一定會得到3
不會改變原始輸入參數,或是外部的環境,所以沒有副作用
不依頼其他外部的狀態,變量或常量
*********************************

 

// 不純粹(impure),splice會改變到原數組 const firstThree = function(arr) { return arr.splice(0,3) }
// 純粹(pure),slice會返回新數組 const firstThree = function(arr) { return arr.slice(0,3) }

 #########################

非純函數:
let count = 1;
let increaseAge = function(value) { return count += value }

############################################
var name = "xueyou"

function test(){
name="xiaoming"
}

test()
#################################
var obj= {
name:"xueyou"
}

function test(newobj){
//傳參,如果復雜類型的, 淺復制
newobj.name="xiaoming"
}
test(obj)
#################################
function test(a){

return Math.random()+"xueyou"+a
}

test(1);

 

################################

var reducer = (prevState = [],action={})=>{

action [type:"a",payload:[1,2,3]]
prevState = [...prevState,...action.payload] //修改了
var a = [...prevState,...action.payload] //然后返回a 這個沒有修改

return [...prevstate,...action.payload]; //直接返回這個也沒有修改
}

########################################


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM