主頁 > 企業開發 > 記錄--你真的能區分JavaScript的各種匯入匯出方式嗎?

記錄--你真的能區分JavaScript的各種匯入匯出方式嗎?

2023-06-06 19:06:49 企業開發

這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助

前言 ????

我們在無論是在查閱別人的代碼,還是在實際專案開發的程序中,肯定都會使用匯入匯出的功能,有時候我們會搞混這幾種方式到底有什么區別,今天我們就來細致的區分一下:

匯入匯出方式????

我們都知道最常見的幾種匯出方式無非是exportexportsexport defaultmodule.exports這幾種,常見的匯入方式則就是importrequire,那么他們到底有什么區別呢?我們一起來看一下:

最為新手小白的我們在看到第一眼的時候肯定會一臉懵,其實我們可以將他們根據不同的JavaScript規范來分開來看

export和export default

exportexport default是ES6的規范

這兩種方式其實沒有什么本質的區別,我們一起來看一下示例:

使用export default這種匯出方式叫做默認匯出(暴露)

var name = "小明";
var fun = function () {
  console.log(name);
};
export default { name, fun };
-----------------------
export default  function() {
    console.log ('export 不能這樣子')
}

這里我們可以看到我們宣告了一個函式,里面列印了變數name的值,然后我們使用export default匯出了一個函式物件,也可以直接默認的匯出一個函式,

值得注意的是,在一個js檔案中只能有一個export default,不能重復的書寫,否則會報錯,而我們在接收這個匯出的物件的中的內容的時候我們需要使用import來進行匯入,

幾個容易錯誤的點:

export default const name3 = 'error'; //這樣匯出的方式是錯誤的
-----------------------
var name3="小紅";
export default name3;//這樣是正確的

當然接識訓出的值的時候也需要注意

import接識訓出的值:

我們在使用export default匯出的時候我們在接受值的時候需要注意

import text from "app.js"

我們假設需要匯出內容的是app.js這個檔案,我們在接收的時候可以自己定義一個變數名稱,就像示例中的test,當然如果想要獲取匯出物件中的內容就可以使用解構的語法,這一點與export是有區別的

export匯出示例:

var age=20; var open=true;
export {age,open} //等同于下邊
export {age}
export {open}
export const fun=()=>{console.log("hhh")}
export const age1 = 23 //let 也行

在export中我們可以一口氣匯出多個變數或者物件,函式等而且我們也可以向最后一行代碼那樣在匯出的時候定義變數名稱,有一點需要注意使用export匯出的內容必須有名稱,就比如匯出函式的時候不能像默認暴露那樣直接匯出一個匿名函式,

匯入時的注意點:

import {age,open} from "app.js"
import {fun} from "app.js"
import {age1 as age2} form "app.js"

這里要注意我們在匯入的時候一定要加上花括號,而且花括號中的名稱必須和匯出的變數或者函式名稱一樣,這一點時與export default不同的,還有我們匯入在age1可以將其重命名為age2.

module.export 和exports

首先這兩種方式是基于Common.js的規范來定義的,而這個規范是在Node.js中,因此這兩種方式主要是在Node.js中使用

在背景關系中提供了exports物件用于匯出當前模塊的方法或者變數,他是唯一匯出的出口,當然在模塊中還存在module物件,他代表模塊自身,exports就是module的屬性(默認的值是一個空物件),而在Node.js中一個檔案就是一個模塊,所以我們匯出

在模塊之中背景關系提供require來引入外部的模塊,

首先我們先來查看module.exports這種方式,

const a = 1;
const fun = () => {
  console.log(2);
};
module.exports = { a, fun };
var req = require ('../app.js');
console.log(req.a1,req.a)
//1 [Function: fun]

我們在匯出的時候需要注意匯出的先后循序,當然這也可以當作面試出題,比如一下這幾行代碼匯出的先后順序不一樣就會列印出不同的值,我們可以一起來看一下:

const a = 1;
const fun = () => {
  console.log(2);
};
// console.log(fun);
module.exports.a2 = 4;
module.exports = { a, fun };
const req = require("./module.exports");
console.log(req.a, req.fun, req.a2);
//1 [Function: fun] undefined

為什么會有undefined呢?

我們在開始的時候說了我們其實發通過exports這中方式默認是匯出一個空的物件,所以我們通過module.exports.a2這種方式匯出其實是在這個空的物件上面添加了一個a2屬性并且值為4,但是下來通過module.exports匯出的時候,我們通過賦值的方式將之前的物件給覆寫了,因此之前的a2值就沒有了,

同樣如果我們給這兩種匯出的方式換一下先后順序,比如我們這樣寫

module.exports = { a, fun };
module.exports.a2 = 4;

我們就可以獲取到a2的值,因為我們先進行了物件的覆寫,然后在新物件上面增加了一個a2的屬性并且值為4,

exports匯出

其實exportsmodule.exports的一個參考,可以認為是 var exports = module.exports

我們來講解一下他們二者的區別:

  1. 直接賦值和替換物件的行為不同:

    • module.exports = value;:將 module.exports 直接賦值為一個新的值,這個新值會成為模塊的匯出內容,例如:module.exports = { a: 1 };,地址發生了改變直接替換之前的所有內容,
    • exports.key = value;:將一個新的屬性和值添加到 exports 物件中,例如:exports.a = 1;
  2. module.exports 優先級高于 exports

    • 如果在模塊中同時使用 module.exportsexports,那么最侄訓出的內容以 module.exports 為準,也就是說,exports 物件的變化不會影響最侄訓出的內容,

使用exports的誤區

直接上一個例子來給大家演示一下:

const a = 1;
const fun = () => {
  console.log(2);
};
exports.a3 = { a, fun };
const req = require("./module.exports");
console.log(req);
console.log(req.a, req.fun);
//{}
//undefined undefined

為什么會出現這種情況呢?

我們知道在最初的時候module.exportsexports最初是指向同一個物件,也就是他們的地址是相同的,但是在這里我們通過物件給exports賦值的時候實際上已經改變了exports的地址,但是module.exports還是默認的地址指向還是一個空的物件,而我們執行匯出的時候實際上還是通過module.exports,所以最侄訓是匯出了一個空物件,

因此我們在module.exportsexports混用的時候要注意地址的問題,不要直接改變module.exports的地址,如果直接改變了,那么exports的操作就會不生效,如果你想混用,那最好全部用module.exports.x = xxx和exports.xx = xxxx這種寫法,這樣的寫法就沒有改變默認的地址,

exports.a2 = 4;
module.exports.fun = fun;
module.exports.a = a;
--------------------
const req = require("./module.exports");
console.log(req);
//{ a2: 4, fun: [Function: fun], a: 1 }

本文轉載于:

https://juejin.cn/post/7241111319591452729

如果對您有所幫助,歡迎您點個關注,我會定時更新技術檔案,大家一起討論學習,一起進步,

 

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/554470.html

標籤:其他

上一篇:Vue2知識點簡要

下一篇:返回列表

標籤雲
其他(160472) Python(38206) JavaScript(25478) Java(18205) C(15237) 區塊鏈(8270) C#(7972) AI(7469) 爪哇(7425) MySQL(7234) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4585) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1983) 功能(1967) HtmlCss(1952) Web開發(1951) C++(1932) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 記錄--你真的能區分JavaScript的各種匯入匯出方式嗎?

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 前言 🛰🛰 我們在無論是在查閱別人的代碼,還是在實際專案開發的程序中,肯定都會使用匯入匯出的功能,有時候我們會搞混這幾種方式到底有什么區別,今天我們就來細致的區分一下: 匯入匯出方式???? 我們都知道最常見的幾種匯出方式無非是exp ......

    uj5u.com 2023-06-06 19:06:49 more
  • Vue2知識點簡要

    一、雙向系結原理 Vue2采用的是觀察者-發布訂閱模式,利用Object.defineProperty實作對資料已定義屬性的監控(定義觀察者模式), 編譯DOM時決議v-model等屬性以及對input框等注冊事件實作UI和JS的互動(也就是注冊發布訂閱這模式); 詳細的是主要是定義一個Observ ......

    uj5u.com 2023-06-06 19:06:28 more
  • 基于 prefetch 的 H5 離線包方案

    本文主要是介紹團隊在離線包技術方案上的探索,以及基于prefetch的離線包實作方案如何減少維護成本和開發成本。 ......

    uj5u.com 2023-06-06 19:06:09 more
  • Vue自定義指令-讓你的業務開發更簡單

    ## 1、使用場景 在日常開發中,我們會將重復代碼抽象為一個函式或者組件,然后在需要時呼叫或者引入。但是,對于某些功能,這種方法可能不夠優雅或者不夠靈活。例如,我們可能需要在DOM元素上添加一些自定義屬性或者系結一些事件,這些操作可能難以通過函式或組件來實作。這時,[自定義指令](https://v ......

    uj5u.com 2023-06-06 19:05:28 more
  • Vue自定義指令-讓你的業務開發更簡單

    ## 1、使用場景 在日常開發中,我們會將重復代碼抽象為一個函式或者組件,然后在需要時呼叫或者引入。但是,對于某些功能,這種方法可能不夠優雅或者不夠靈活。例如,我們可能需要在DOM元素上添加一些自定義屬性或者系結一些事件,這些操作可能難以通過函式或組件來實作。這時,[自定義指令](https://v ......

    uj5u.com 2023-06-06 11:36:20 more
  • React學習時,自己擬定的一則小案例(table表格組件,含編輯)

    某次在Uniapp群看到有人問uniapp如何操作dom元素。 ![](https://img2023.cnblogs.com/blog/3112483/202306/3112483-20230605170528006-986335874.png) 他想對這張表標紅的區域,做dom元素獲取,因為產品 ......

    uj5u.com 2023-06-06 11:30:26 more
  • 記錄--JavaScript 中有趣的 9 個常用編碼套路

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 1?? set物件:陣列快速去重 常規情況下,我們想要篩選唯一值,一般會想到遍歷陣列然后逐個對比,或者使用成熟的庫比如lodash之類的。 不過,ES6帶來了一個新玩意兒!它引入了一個全新的物件型別:Set!而且,如果結合上...展開運算 ......

    uj5u.com 2023-06-06 11:30:19 more
  • 幫你梳理了一份前端知識架構圖

    列一份前端知識架構圖 在上一篇文章中,我們簡要地總結了前端的學習路徑與方法,我們提到的第一個學習方法就是:建立知識框架。那么,今天我們就一起來列一份前端的知識框架圖。 在開始列框架之前,我想先來談談我們的目標。實際上,我們在網上可以找到很多參考資料,比如 MDN 這樣的參考手冊,又比如一份語言標準, ......

    uj5u.com 2023-06-06 11:30:00 more
  • 【一步步開發AI運動小程式】十一、人體關鍵點跳躍追蹤

    > 隨著人工智能技術的不斷發展,阿里體育等IT大廠,推出的“樂動力”、“天天跳繩”AI運動APP,讓**云上運動會、線上運動會、健身打卡、AI體育指導**等概念空前火熱。那么,能否將這些在APP成功應用的場景搬上小程式,分享這些概念的紅利呢?本系列文章就帶您一步一步從零開始開發一個AI運動小程式,本 ......

    uj5u.com 2023-06-06 11:29:18 more
  • 如何制作 Storybook Day 網頁上的 3D 效果?

    Storybook 剛剛達到了一個重要的里程牌:7.0 版本!為了慶祝,該團隊舉辦了他們的第一次用戶大會 - [Storybook Day](https://storybook.js.org/day)。為了更特別,在活動頁面中添加了一個視覺上令人驚嘆的 3D 插圖。 原文:[How we built ......

    uj5u.com 2023-06-06 11:15:15 more