//純函數 ---> 不對外界產生副作用的函數就叫純函
純函數: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]; //直接返回這個也沒有修改
}
########################################