上一篇列出了Perl中定義數(shù)組,對象的方式與JS的異同。這里繼續(xù)補充數(shù)組,哈希的相關操作。
一、數(shù)組
可以對數(shù)組進行增刪,插入。與JS不同的是這些函數(shù)都是全局的,JS則是掛在Array.prototype上。
1,對數(shù)組尾部的操作pop(刪除最后的元素)、push(在尾部添加)
@goods = qw/pen pencil/; pop(@goods); # @goods 變成 (pen) push(@goods, 'brush'); # @goods 變?yōu)?(pen, brush)
在Perl中,函數(shù)調用時小括號是可選的(視上下文而定),就象前面使用的print。以下是等價的
pop @goods; # @goods 變成 pen push @goods, 'brush'; # @goods 變?yōu)?(pen, brush)
2,對數(shù)組首部的操作shift(刪除第一個元素)、unshift(在首部添加元素)
3,任意位置刪除或插入splice
4,逆序數(shù)組,Perl有reverse函數(shù),JS沒有對應函數(shù)。
5,排序數(shù)組sort,Perl和JS都有。
2,3,4,5提到的函數(shù)不貼演示代碼了。
6,JS使用length屬性獲取數(shù)組長度,Perl不同,有3種方式獲取
@goods = qw/pen pencil/; # 將數(shù)組變量賦值給一個標量變量 $len = @goods; # 使用scalar函數(shù) $len = scalar(@goods); # 最后一個元素的索引加1 $len = $#goods + 1;
7,遍歷數(shù)組,Perl用foreach函數(shù)
@goods = qw/pen pencil brush/; # 默認的$_ foreach (@goods) { print "$_"."/n"; } # 自定義變量 foreach $item (@goods) { print "$item"."/n"; }
ES5可以用forEach
['pen', 'pencil', 'brush'].forEach(function(item) { console.log(item) })
二、哈希
1,獲取keys和values
%person = ( name => 'Jack', age => 30, ); @k = keys %person; # (name, age) @v = values $person; # ('Jack', 30)
ES5有Object.keys,但沒有Object.values
person = { name: 'Jack', age: 30 } Object.keys(person) // ['name', 'age']
2,獲取鍵值對(key-value)數(shù)量(對Perl來說很容易)
%person = ( name => 'Jack', age => 30, ); $len = keys %person; # 2
對于JS來說,可能需要for in整個對象
function getObjLen(obj) { var len = 0 for (var a in obj) { if (obj.hasOwnProperty(a)) len++ } return len } var person = { name: 'Jack', age: 30 } getObjLen(person) // 2
3,遍歷對象
Perl有兩種方式,一種while+each,一種獲取keys再foreach。
%person = ( name => 'Jack', age => 30, ); # 方式1 while ( ($k, $v) = each %person ) { print "$k: $v"."/n"; } # 方式2 @keys = keys %person; foreach(@keys) { print "$_: ".$person{$_}."/n"; }
JS一個for in即可。
新聞熱點
疑難解答