現代 JavaScript (ES6+) 入門到實戰(三):字符串與對象的魔法升級—模板字符串/結構賦值/展開運算符

在前兩篇,我們升級了變量和函數。今天,我們要給 JavaScript 中最常用的兩種數據類型——字符串(String)和對象(Object)——裝備上 ES6 帶來的強大魔法。

準備好告別丑陋的 + 號拼接和重復的對象屬性賦值了嗎?

一、回憶殺:令人抓狂的字符串拼接

在項目中,我們經常需要動態地將變量和 HTML 組合起來。在 ES5 時代,這通常是一場災難。

【過去我們這么寫 (ES5)】

var user = {name: '小明',age: 18,website: 'https://example.com'
};var profileCard ='<div class="card">' +'<h2>' + user.name + '</h2>' +'<p>年齡:' + user.age + '</p>' +'<p>個人主頁:<a href="' + user.website + '">' + user.website + '</a></p>' +'</div>';console.log(profileCard);

這種寫法不僅丑陋,而且非常容易出錯:

  • 大量的 + 號和引號,很容易漏掉一個。
  • 不能自由換行,否則會報語法錯誤。
  • 變量和字符串混在一起,難以閱讀。

二、進化時刻:模板字符串 (Template Literals) 登場

ES6 引入了模板字符串,它徹底改變了我們處理字符串的方式。

【現在我們這么寫 (ES6+)】

const user = {name: '小明',age: 18,website: 'https://example.com'
};const profileCard = `<div class="card"><h2>${user.name}</h2><p>年齡:${user.age}</p><p>個人主頁:<a href="${user.website}">${user.website}</a></p></div>
`;console.log(profileCard);

魔法揭秘:

  1. 使用反引號 `:模板字符串使用反引號(鍵盤左上角,數字1左邊的那個鍵)包裹,而不是單引號或雙引號。
  2. 自由換行:在反引號內,你可以隨意換行,所有空格和縮進都會被保留。
  3. 嵌入變量 ${}:使用 ${...} 語法,你可以輕松地將任何變量或表達式嵌入到字符串中。{} 里面甚至可以進行計算,比如 ${user.age + 1}

現在,代碼的可讀性和可維護性都得到了質的飛躍!


三、回憶殺:繁瑣的對象操作

處理對象是日常開發的核心任務之一。在 ES5 中,從對象里取值或者創建新對象,往往伴隨著大量的重復代碼。

【過去我們這么寫 (ES5)】

var person = { name: '張三', age: 30, city: '北京' };// 1. 從對象取值
var name = person.name;
var age = person.age;console.log('你好,我叫' + name + ',今年' + age + '歲。');// 2. 創建新對象
var newName = '李四';
var newAge = 25;var newPerson = {name: newName,age: newAge,city: '上海'
};

四、進化時刻:解構與簡寫

ES6 為對象和數組帶來了“解構賦值”和一系列簡寫語法,讓代碼變得極其精煉。

1. 解構賦值 (Destructuring Assignment)

解構賦值允許你從對象或數組中“提取”值,并直接賦給變量。

【現在我們這么寫 (ES6+)】

const person = { name: '張三', age: 30, city: '北京' };// 從對象中解構出 name 和 age 兩個變量
const { name, age } = person;console.log(`你好,我叫${name},今年${age}歲。`); // 使用了模板字符串!

一行代碼 const { name, age } = person; 就等同于 ES5 的兩行賦值語句。變量名必須和對象屬性名相同。你也可以給變量起別名:const { name: personName } = person;

2. 對象屬性簡寫

當你要創建的對象屬性名和你手中的變量名相同時,可以進行簡寫。

【現在我們這么寫 (ES6+)】

const newName = '李四';
const newAge = 25;// 因為變量名和屬性名相同,可以簡寫
const newPerson = {name: newName, // 可簡寫為 nameage: newAge,   // 可簡寫為 agecity: '上海'
};// 最終簡寫形式
const simplifiedPerson = {name: newName,age: newAge,city: '上海'
};

3. 展開運算符 (...)

展開運算符像一個魔法棒,可以“展開”一個對象或數組,常用于合并或克隆。

const baseConfig = { host: 'localhost', port: 8080 };
const userConfig = { port: 3000, user: 'admin' };// 合并對象,userConfig 會覆蓋 baseConfig 中的同名屬性
const finalConfig = { ...baseConfig, ...userConfig };
// finalConfig 的結果是: { host: 'localhost', port: 3000, user: 'admin' }// 淺克隆一個對象
const clonedPerson = { ...person };

總結

  • 模板字符串`${},徹底解決了字符串拼接的痛點,讓代碼更清晰。
  • 解構賦值讓從復雜數據結構中提取信息變得無比簡單。
  • 對象屬性簡寫展開運算符讓創建和合并對象的操作大大簡化。

掌握了這些“魔法”,你的代碼不僅會寫得更快,也會讓同事對你刮目相看。

在下一篇,我們將把目光投向數組,學習 mapfilter 等強大的高階函數,看看如何用更聲明式、更優雅的方式來處理集合數據。敬請期待!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/86791.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/86791.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/86791.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

GitLab 備份恢復與配置遷移詳盡教程(實戰版)

&#x1f6e0; GitLab 備份恢復與配置遷移詳盡教程&#xff08;實戰版&#xff09; &#x1f9f1; 一、環境準備 1.1 檢查版本一致性 恢復目標機 GitLab 版本必須與備份文件所用版本一致或兼容&#xff08;推薦相同版本&#xff09; 查看當前 GitLab 版本&#xff1a; sudo g…

英飛凌高性能BMS解決方案助力汽車電動化

隨著電動汽車越來越被大眾接受&#xff0c;車輛電氣化、智能化程度越來越高&#xff0c;如何提高電動汽車的續航里程&#xff0c;同時保障車輛安全可靠持久運行是當前最主要的技術難題之一。而先進的電池管理系統 (BMS)有助于克服電動汽車廣泛普及的關鍵障礙&#xff1a;續航里…

react + ant-design實現數字對比動畫效果:當新獲取的數字比之前展示的數字多或少2時,顯示“+2”或“-2”的動畫效果

react ant-design實現數字對比動畫效果&#xff1a;當新獲取的數字比之前展示的數字多或少2時&#xff0c;顯示“2”或“-2”的動畫效果 1. 創建獨立的 AnimatedValue 組件 // components/AnimatedValue/index.jsx import React, { useState, useEffect, useRef } from reac…

自動化測試--Appium和ADB及常用指令

1.Appium Appium工具庫&#xff1a; appium server&#xff1a;服務器&#xff08;類似于瀏覽器的驅動&#xff09;&#xff0c;核心進行客戶端命令的接受&#xff0c;完成設備的自動化指令 appium client&#xff1a;客戶端&#xff0c;讓代碼進行調用&#xff0c;發送自動化的…

2025.6.29總結

有一點我很好奇&#xff0c;工作后&#xff0c;我該拿什么去衡量自己的進步呢&#xff1f; 在我的大學四年&#xff0c;確實有個量化的標準&#xff0c;讀了多少本書&#xff0c;寫了多少篇總結&#xff0c;多少篇技術博客&#xff0c;多少行代碼&#xff0c;運動了多少公里&a…

Docker 部署 Kong云原生API網關

Docker 部署 Kong云原生API網關 本指南提供了在 Docker Compose 上配置 Kong Gateway 的步驟&#xff0c;基于有數據庫模式的配置。本指南中使用的數據庫是 PostgreSQL。 前置條件 準備一臺Ubuntu服務器&#xff1a; 節點IP: 192.168.73.11操作系統&#xff1a; Ubuntu 24…

深度剖析 Apache Pulsar:架構、優勢與選型指南

Apache Pulsar 是一款云原生分布式消息流平臺&#xff0c;融合了消息隊列、流處理和存儲能力&#xff0c;采用獨特的“存儲計算分離”架構&#xff08;Broker 無狀態 BookKeeper 持久化存儲&#xff09;。以下從核心特性、對比優勢及適用場景展開分析&#xff1a; 一、Pulsar…

java 導出word 實現循環表格

如果是固定的值 用 {{}} 即可 但是如果是循環表格&#xff0c;那么就需要制定模板為如圖 然后在處理表格數據時候&#xff1a; /*** 傳入 節點對象 返回生成的word文檔* param flangeJoint* return* throws IOException*/private XWPFTemplate getXwpfTemplate(CmComplaintEn…

XIP (eXecute In Place)

NOR Flash 能直接執行代碼(XIP)而 NAND Flash 不能,根本原因在于它們的物理結構和訪問接口存在本質區別。下面用技術原理 + 現實比喻幫你徹底理解: 1. XIP 是什么? XIP (eXecute In Place) 指代碼不需要從存儲介質復制到 RAM,而是 CPU 直接從存儲介質(如 Flash)中讀取…

【android bluetooth 協議分析 10】【AVRCP詳解1】【PlaybackStateCompat類如何查看】

1. 問題 android/app/src/com/android/bluetooth/avrcpcontroller/AvrcpControllerService.java import android.support.v4.media.MediaBrowserCompat.MediaItem; import android.support.v4.media.session.PlaybackStateCompat;private int toPlaybackStateFromJni(int fro…

【AI學習從零至壹】LLM模型prompt開發及?模型應?

LLM模型prompt開發及?模型應? ?語?模型 LLM如何構建?個AI對話系統關于模型的訓練 ollama調?LLM模型設置API KEY測試一個對話 prompt提示詞提示詞結構特征提示詞的五大核心價值1. 信息傳遞的精準性2. 輸出質量的可控性3. 用戶意圖的對?性4. 復雜任務的拆解性5. 倫理?險的…

ubuntu20.04如何給appImage創建快捷方式

ubuntu20.04如何給appImage創建快捷方式 1. 確保AppImage是可執行的 chmod x /path/to/your/appimage2. 創建.desktop文件 在~/.local/share/applications/目錄下創建一個新的 .desktop 文件&#xff1a; vi ~/.local/share/applications/your-appname.desktop添加以下內容…

RT-Thread 詳解:國產開源實時操作系統

一、RT-Thread 概述 定義&#xff1a;RT-Thread 是中國自主研發的開源實時操作系統&#xff08;RTOS&#xff09;&#xff0c;兼具實時性與物聯網&#xff08;IoT&#xff09;特性&#xff0c;支持從資源受限的 MCU&#xff08;如 STM32、ESP32&#xff09;到高性能處理器&…

Wan2 1-VACE

簡介 VACE是阿里新開源的視頻編輯/生成框架&#xff0c;號稱能夠執行任意的視頻編輯/生成。總體而言&#xff0c;該模型在整體結構上并沒有太大改變&#xff0c;僅僅是在原Wan2.1模型的基礎上&#xff0c;加了一個接受mask和視頻輸入的controlnet而已。但是這篇文章認為&#…

基于 opencv+yolov8+easyocr的車牌追蹤識別

&#xff08;本項目所有代碼打包至我的資源中&#xff0c;大家可在我的文章底部選擇下載&#xff09; 目錄 需求 實現效果 學習視頻 大致思路 代碼實現 資源下載 需求 通過車輛識別技術&#xff0c;識別視頻中每個車輛及其車牌號&#xff0c;車輛應進行追蹤&#xff0c;避免重復…

sqlserver函數與過程(二)

過程 SQLserver 過程是具有特定功能&#xff0c;可多次對數據表操作的獨立模塊。返回值通常用return 返回整數 0&#xff0c;1…。(可選&#xff09;也可通過output 參數或select 語句返回結果集。 1.過程的定義 本過程定義了一個過程&#xff0c;輸入一個動態SQL語句&#…

OpenCV學習3

1、創建圖像窗口滑動條 OpenCV 4中通過createTrackbar()函數在顯示圖像的窗口上創建滑動條。 int cv::createTrackbar(const String &trackbarname,const String &winname, int *value, int count, TrackbarCallback onChange 0, void *us…

SRS流媒體服務器之本地測試rtc推流bug

SRS環境版本 commit 44f0c36b61bc7c3a1d51cb60be0ec184c840f09d Author: winlin <winlinvip.126.com> Date: Wed Aug 2 10:34:41 2023 0800 Release v4.0-r5, 4.0 release5, v4.0.271, 145574 lines. bug1: 無法推流 WebRTC推流必須是HTTPS或者localhost&#xff1a;Ht…

物理服務器是指的什么?作用有哪些?-哈爾濱云前沿

物理服務器是一種基于傳統硬件架構構建的服務器&#xff0c;物理服務器是具有處理器、硬盤和網絡接口等硬件組件的獨立服務器&#xff0c;可以用于托管和存儲數據服務&#xff0c;&#xff0c;是計算機網絡的核心組件之一&#xff0c;本文就來詳細了解一下物理服務器。 物理服務…

Lua現學現賣

一、Lua的變量類型 全局變量&#xff1a;MyVar 局部變量&#xff1a;local MyVar 二、Lua的數據類型 1.nil&#xff1a;一個空值 類似C的nullptr 2.Boolean&#xff1a;true/false 類似C的bool 3.string&#xff1a;字符串 類似C的std::string 4.Number&#xff1a;數字 類似C…