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