JavaScript連載20-數據存儲方式、內置對象Array詳解

来源:https://www.cnblogs.com/ruigege0000/archive/2020/06/27/13200606.html

一、堆和棧,數據的存儲方式 1.註意點: JS中是沒有堆和棧的概念,我們用堆和棧來講解,目的就是方柏霓講解,存儲方式是一致的。 2.存儲方式: 基礎數據類型進行值傳遞,複雜數據類型進行地址傳遞 <script> //1.基本數據類型 var str1 = "xiaoliao"; var str2 = ...


一、堆和棧,數據的存儲方式

1.註意點:

JS中是沒有堆和棧的概念,我們用堆和棧來講解,目的就是方柏霓講解,存儲方式是一致的。

2.存儲方式:

基礎數據類型進行值傳遞,複雜數據類型進行地址傳遞

<script>
    //1.基本數據類型
    var str1 = "xiaoliao";
    var str2 = str1;//基本數據類型是傳輸的值,引用數據類型傳輸的是記憶體地址

    str1 = "itLike";
    console.log(str1);
    console.log(str2);
    console.log("========================");
    //2.複雜類型
    function Person(name,age,intro) {
        this.name = name;
        this.age = age;
        this.intro = intro;
    }

    var p1 = new Person("xiaoming",45,"This is a virtuous person!");
    var p2 = p1;
    p1.name = "daliao";
    console.log(p1.name);
    console.log(p2.name);//可以看出來傳輸的是內容地址
    console.log("============================");
    //3.基本類型作為函數的參數
    var num1 = 10,num2 = 23;
    //可以看出來函數也是值傳遞
    fn(num1,num2);
    console.log("num1="+num1);
    console.log("num2="+num2);
    function fn(n1,n2) {
        n1 *= 2;
        n2 /= 2;
        console.log("n1="+n1);
        console.log("n2="+n2);
    }
    console.log("=========================");
    //4.複雜類型作為函數參數
    function Person(name,age,sex) {
        this.name = name;
        this.age = age;
        this.sex = sex;
    }

    function func(person) {
        person.name = "周傑倫";
        
    }

    var  p = new Person("xiaoming",45,"男");
    console.log(p.name)
    func(p);
    console.log(p.name);//可以看出來是地址傳遞
</script>

 

 

運行結果20.1

二、內置對象

1.Array對象屬性

  • 檢測一個對象是否是數組

兩種方法,內置方法instanceof和一種成員方法isArray(變數)

    //1.檢測一個對象是否是數組
    var arr = ["zhansan","lisi","wangwu"];
    console.log(arr instanceof Array);
    console.log(arr instanceof Object);//這句話可以看出數組也是一種對象
    console.log(arr instanceof Function);//數組不是函數類型
    //另一種方法,成員方法     .isArray()
    console.log(Array.isArray(arr));
    console.log(Array.isArray("arr"));

 

 

運行結果20.1

  • 數組常用API

toString()把數組轉換成字元串,逗號分隔每一項;valueOf成員方法返回數組本身。

    //2.數組常用API
    var arr = ["zhangsan","lisi"];
    console.log(arr.toString());
    console.log(arr.valueOf());//返回的是數組本身
    //3.join(sperator)方法,將數組的元素組成一個字元串,以seperator為分隔符,省略的話則預設用逗號為
    //分隔符,該方法只接受一個參數:即分隔符。
    console.log(arr.join("-"));
    console.log(arr.join("^"));
    //4.壓棧,出棧
    arr.push("附加的");//返回值就是數組的總長度
    console.log(arr.toString());
    arr.pop();
    console.log(arr.toString());
    console.log("=======================");
    //5.shift()函數,是相當於從頭部進行刪除
    arr.push("sdohf");
    arr.push("nvl");
    console.log(arr.toString());
    arr.shift();
    console.log(arr.toString());

 

 

運行結果20.3

三、源碼:

  • D20_1_DataExpressionInMemory.html
  • D20_2_Built-inObject.html \
  • 地址:
    https://github.com/ruigege66/JavaScript/blob/master/D20_1_DataExpressionInMemory.html 
    https://github.com/ruigege66/JavaScript/blob/master/D20_2_Built-inObject.html \
  • 博客園:https://www.cnblogs.com/ruigege0000/
  • 歡迎關註微信公眾號:傅里葉變換,個人賬號,僅用於技術交流,後臺回覆“禮包”獲取Java大數據學習視頻禮包
  • 20.4

您的分享是我們最大的動力!

更多相關文章
  • 語句執行過程中,由於各種原因使得語句不能正常執行,可能會造成更大錯誤或整個系統的崩潰,所以PS/SQL提供了異常(exception)著一處理的方法來防止此類情況的發生。在代碼運行的過程中無論何時發生錯誤,PL/SQL都能控製程序自動地轉向執行異常部分。 1.預定義異常 預定義異常是由於系統產生的。 ...
  • 第一種形式: decode(條件,值1,返回值1,值2,返回值2,…值n,返回值n,預設值) ​ 實現數據的彙總: 源數據: ​ 彙總後的數據:使用decode函數處理數據後對dname欄位進行彙總。 ​ 第二種形式: decode(欄位或欄位的運算,值1,值2,值3);當欄位或欄位的運算的值等於值 ...
  • 1、coalesce函數的用法 1.1 取出第一個不為空的列的數據。 ​ 1.2 coalesce函數裡面的數據類型,必須全部都跟第一列的數據類型一致。 ​ 原因為第一個參數為數值,第二個參數為字元串;可通過轉換數據類型來使用,如下圖: ​ ...
  • 函數參數:lpad( string, padded_length, [ pad_string ] ) 參數說明: string:源字元串; padded_length: 即最終結果返回的字元串的長度;如果最終返回的字元串的長度比源字元串的小,那麼此函數實際上對源串進行截取處理,與substr(str ...
  • 本博客SQL腳本地址:gitee 準備工作 已知有如下4張表: 學生表:student(學號,學生姓名,出生年月,性別) 成績表:score(學號,課程號,成績) 課程表:course(課程號,課程名稱,教師號) 教師表:teacher(教師號,教師姓名) 一、創建資料庫和表 為了演示題目的運行過程 ...
  • 1. 獲取中獎用戶ID,隨機彈出之後集合中就不存在了【set】 2. 存儲活動中中獎的用戶ID,保證同一個用戶不會中獎兩次【set】 3. 存儲粉絲列表,value 為粉絲的用戶ID,score 是關註時間【zset】 4. 存儲學生成績,value 為學生的ID,score 是考試成績【zset】... ...
  • 我們知道數據的存儲和檢索是兩個很重要的功能,當我們的數據量大了,怎麼能快速的檢索數據呢,答案是使用索引,可索引具體的技術實現有很多,選擇哪一種呢,我就以mysql為例記錄下它為什麼選擇了B+樹作為索引的實現方式。 1. 索引簡介 索引是一種用於快速查詢行的數據結構,就像一本書的目錄就是一個索引,如果 ...
  • 前言 本文將帶大家學習使用前端開發神器-charles,從基本的下載安裝到常見配置使用,為大家一一講解。 一、花式誇獎Charles 截取 Http 和 Https 網路封包。 支持重髮網絡請求,方便後端調試。 支持修改網路請求參數。 支持網路請求的截獲並動態修改。 支持模擬慢速網路。 好,騎上我心 ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...