小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

JS數組和字符串匯總

 頭號碼甲 2021-11-05

數組

1. 基本常識

數組是引用類型的一種,什么是引用類型呢?

和原始類型不同,引用類型變量中存放的僅僅是引用對象的內存地址。

所以,當我們復制引用類型的時候,復制的僅僅是它的地址罷了。

也就是說,任意一個變量發(fā)生變化,地址上的對象也隨之變化。

舉個例子:

var a = [1,2,3];
var b = a;
b[0] = 'first';
console.log(b[0]); // 'first'
console.log(a[0]); // 'first'

2. 常用屬性與方法

屬性:Array.length 獲取數組長度(也就是數組元素的個數)

方法:

  • 檢查數組
    value instanceof Array => true / false
    Array.siArray(value) => true / false

  • 轉換方法
    toString() / join(sep) => 變成字符串,自定義分隔符(默認逗號分隔)
    valueOf() => 返回指定對象本身

  • 棧方法
    放砝碼,先進后出
    push() => 在數組末尾添加元素
    pop() => 在數組末尾刪除元素

  • 隊列方法
    裝子彈,先進先出
    unshift() => 在數組開頭添加元素
    shift() => 在數組開頭刪除元素

  • 重排序方法
    reverse() => 反轉
    sort() => 升序(值逐漸升高)
    注意:sort()比較的是字符串!sort()中可以傳入一個比較函數。

  • 操作方法
    基于原數組,在新的副本上操作(不影響原數組),只是返回新數組。
    concat() => 數組元素拼接 在數組末尾添加元素,如果是數組那就將數組里的元素添加到末尾
    slice() => 切片 顧頭不顧尾
    splice(startIndex, deleteNum, newItem) => 有三個參數,分別是開始位置、移除項數、被插入項。可以進行三種操作:刪除、插入、替換。

    • Array.splice(1, 2) => 從下標1開始,刪除2個元素(下標1和下標2被刪)。
    • Array.splice(1, 0, 'newItem'); => 在下標1處插入元素'newItem'。
    • Array.splice(1, 0, 'newItem01', 'newItem02'); => 在下標1處插入多個元素。
    • Array.splice(1, 2, 'newItem01', 'newItem02'); => 在下標1處先刪除2個元素,再插入新的元素(同上,1個或多個)。
  • 位置方法
    indexOf(value, [seekIndex]) => value的下標 第一個參數表示要查找的元素,第二個參數表示查找的起始位置。
    lastIndexOf(value) => value最后一次出現(xiàn)的下標
    注意:如果返回-1,表示數組中沒有該項。

  • 迭代方法 (回調函數中第一個參數是數組項,第二個參數是下標,第三個參數是當前數組。)
    forEach(function(item,index,arr){...}) => 遍歷數組 相當于原生的for循環(huán)
    every(function(item,index,arr){...}) => 數組里面所有的元素都要符合條件,才返回true。
    some(function(item,index,arr){...}) => 數組中任何一個元素符合條件,就返回true。
    map(function(item,index,arr){...}) => 做數據交互映射,可以重新整理數據結構。對每一項給定函數操作,返回新的數組。(常用!)
    filter(function(item,index,arr){...}) => 過濾數據,把返回true的留下來。對每一項給定函數操作,返回符合條件的數組。

  • 歸并方法(回調函數中第一個參數是前一個累積值,第二個是當前值,第三個是下標,第四個是當前數組。)
    reduce(function(prev, cur, index, arr){...}) => 對給定數組按照從左到右的順序,執(zhí)行給定的操作,并返回結果。(求數組的和,求階乘)
    reduceRight(function(prev, cur, index, arr){...}) => 對給定數組按照從右往左的順序,執(zhí)行給定的操作,并返回結果。

字符串

1. 基本常識

字符串作為基本數據類型,它是不可以改變原始值的,屬于不可變類型。(數組屬于可變類型)

那么,它為什么可以有屬性和方法呢?

因為它是包裝類,首先會通過new String()創(chuàng)建一個字符串對象,這樣就擁有了對象的屬性和方法。

當屬性和方法調用完畢后,這個字符串對象就會銷毀。

2. 常用屬性與方法

屬性:String.length 獲取字符串長度(字符個數)

方法:

  • 字符方法
    charAt(index) => 返回對應下標的字符
    charCodeAt(index) => 返回對應下標的字符編號

  • 轉換方法
    String.split(sep) => 變成數組,自定義分隔符

  • 操作方法
    和數組的操作方法concat()、slice()、splice()類似。
    String.concat() => 字符串拼接(和加號的作用相同,先把符號左右轉換成字符串然后相加)
    String.slice() => 切片,顧頭不顧尾
    String.substring() => 同slice() 注意:傳入負數直接轉換為0
    String.substr(stratIndex, length) => 也是切片,不同的是第一個參數是開始下標位置,第二個參數是操作的字符長度。

  • 位置方法
    indexOf() => 返回查找字符的下標
    lastIndexOf() => 最后出現(xiàn)的下標
    注意:沒有找到返回-1,第二個參數表示開始查找的下標

trim() => 刪除前置和后綴的所有空格

  • 大小寫轉換
    toLowerCase() => 字符串全部小寫
    toUpperCase() => 字符串全部大寫

  • ES6字符串新方法

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多