【每日前端面經】2023-02-29

題目來源: 牛客

如何理解前端這個崗位

簡單地說就是設計師做好網頁效果圖,前端將效果圖轉化成頁面,之后交給后端程序員,中間的這段工作就是前端

瀏覽器如何渲染HTML

  • 將載入的HTML文件解析成DOM樹,并且將各個標記標識解析成DOM樹的各個節點
  • 將解析成的DOM樹和CSS規則樹進行關聯生成渲染樹
  • 進入布局階段,為DOM樹的每個節點分配在屏幕上出現的確切坐標
  • 進入繪制階段,在這里渲染引擎的工作就結束了,接下來就交給后端對渲染樹的每個節點進行繪制,呈現出頁面效果

重繪會引起重排么

重繪是指某些元素的外觀被改變,重拍是指重新生成布局排列元素。單單改變元素的外觀,肯定不會引起網頁重新生成布局,但當瀏覽器完成重拍之后,將會重新繪制受到此次重排影響的部分。也就是說:重繪不一定導致重排,但重排一定會導致重繪

使用scale屬性會引起重繪還是重排

scale只能引起重繪而不是重排,transform的所有屬性都不會引起重排

瀏覽器事件循環

  • 執行同步代碼
  • 執行宏任務
  • 將微任務添加到任務隊列
  • 宏任務執行完畢后,執行任務隊列

圖片懶加載

簡單來說,就是如果可視區域里面看不到圖片,就先不加載圖片

addEventListener("scroll", () => {const images = document.querySelectorAll('img');images.forEach(image => {const clientHeight = document.documentElement.clientHeight;const scrollTop = document.documentElement.scrollTop;if (image.offsetTop < clientHeight + scrollTop) {image.setAttribute('src', image.getAttribute('data-src'));}});
});

路由懶加載

當打包構建應用時,JS包會變得非常大,影響頁面加載。如果把不同路由對應的組件分割成不同的代碼塊,然后當路由被訪問的時候才加載對應組件,這樣就更加高效了

  • Vue異步組件
  • ES6標準import()
  • webpack的require/ensure

路由鑒權

  • 路由攔截
  • 動態路由

請求攔截器

  • HandlerInterceptor: 攔截的目標為請求的地址
  • ClientHttpRequestInterceptor: 攔截的目標為請求的方法
  • RequestInterceptor: 對RestTemplate的請求進行攔截
  • AsyncClientHttpRequestInterceptor: Feign攔截器,也就是一個HTTP攔截器

堆棧和隊列

  • 堆棧:最后一個放入堆棧中的物體總是最先被拿出來,這個特性通常被稱為后進先出
  • 隊列:先進入隊列中的元素總是最先被拿出來,被稱為先進先出

對鏈表的理解

鏈表是一種物理存儲單元上非連續、非順序的存儲結構,數據元素的邏輯順序是通過鏈表中的指針鏈次序連接的,由一系列結點組成。分為單鏈表、循環鏈表、雙向鏈表、雙向循環鏈表等

數組和鏈表的存儲結構

  • 數組的內存空間是連續的,可以通過索引快速訪問任意位置的元素,適合于按照順序存儲和快速訪問數據的場景
  • 鏈表的空間可以是不連續的,適合在中間位置插入或刪除元素,適合與頻繁變動數據集合的場景

數組的長度限制

根據ES5的規范,數組的最大長度由一個無符號32位整數綁定,因此最長的數組由 2 32 ? 1 個 2^{32}-1個 232?1元素

附件的上傳和下載怎么實現

  • 上傳: 先獲取到文件對象然后利用表單FormData對象進行傳輸
  • 下載: 手動新建一個a標簽然后自動觸發下載

獲得樹中某個節點的層級

class Node {value: string;lchild: Node;rchild: Node;
}function getLevel(head, target, level=1) {if (head === null) return 0;if (head.value === target.value) {return level;} else {l = getLevel(head.lchild, target, level + 1);if (l !== 0) return l;return getLevel(head.rchild, target, level + 1);}
}

前端開發是做什么的?工作職責有哪些?
瀏覽器是如何解析和渲染HTML的🔥🔥🔥
重排(reflow)和重繪(repaint)
css zoom和scale的使用
瀏覽器事件循環看這一篇就夠了
淺析圖片懶加載(三種實現方法與兩種優化方式)
vue-router路由懶加載以及三種實現方式
vue-鑒權的兩種方法之路由攔截
幾種常見的攔截器使用
數組與鏈表:數據存儲結構的比較
面試官:說說你對鏈表的理解?常見的操作有哪些?
GuoXY
7-5 求二叉樹中指定節點的層次
js數組有最大長度嗎?

新人發文,禮貌球館??

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

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

相關文章

SQL的窗口函數

SQL的窗口函數 文章目錄 SQL的窗口函數1. 介紹2. 聚合函數0.數據準備1. AVG2. COUNT3. MAX4. MIN5. 標準差6. SUM 3. 排序函數1. CUME_DIST2. RANK, DENSE_RANK, ROW_NUMBER3. PERCENT_RANK4. NTILE 4. 值函數(偏移函數)1. FIRST_VALUE2. LAST_VALUE3. LAG4. LEAD5. NTH_VALUE …

ChatGPT4.0 的優勢、升級 4.0 為什么這么難以及如何進行升級?

前言 “ChatGPT4.0一個月多少人民幣&#xff1f;” ”chatgpt4賬號“ ”chatgpt4 價格“ “chatgpt4多少錢” 最近發現很多小伙伴很想知道關于ChatGPT4.0的事情&#xff0c;于是寫了這篇帖子&#xff0c;幫大家分析一下。 一、ChatGPT4.0 的優勢 &#xff08;PS&#xff1a;…

LINUX基礎培訓二十七之shell標準輸入、輸出、錯誤

一、Shell 輸入/輸出重定向 大多數 UNIX 系統命令從你的終端接受輸入并將所產生的輸出發送回??到您的終端。一個命令通常從一個叫標準輸入的地方讀取輸入&#xff0c;默認情況下&#xff0c;這恰好是你的終端。同樣&#xff0c;一個命令通常將其輸出寫入到標準輸出&#xff…

【樹莓派系統配置+python3.8+環境配置踩坑點匯總】raspberrypi

最近又開始搞樹莓派的深度學習模型。很多windows端的環境需要在樹莓派上重新部署&#xff0c;中間出現了非常多的問題。主要以各種庫的下載安裝為主要。 首先&#xff0c;第一個問題&#xff1a; 樹莓派系統燒錄之后&#xff0c;默認apt一般需要升級看&#xff0c;而默認下載…

無窮級數法求Π

任務描述 本關任務&#xff1a;編寫一個無窮級數法計算圓周率的小程序。 相關知識 為了完成本關任務&#xff0c;你需要掌握&#xff1a; 無窮級數法 無窮級數法 π 是個超越數&#xff0c;圓周率的超越性否定了化圓為方這種尺規作圖精確求解問題的可能性。有趣的是&…

【Spring】18 Bean 定義繼承

文章目錄 介紹聲明式配置抽象Bean定義繼承的配置項注意&#xff1a;抽象Bean預實例化結論 Spring 框架提供了一個強大的功能&#xff0c;稱為 Bean 定義繼承&#xff0c; 允許開發人員高效地在 bean 之間重用和自定義配置。在本篇文章中我們將介紹 Bean 定義繼承的概念&#x…

JVM性能優化

運行時優化 方法內聯 方法內聯&#xff0c;是指 JVM在運行時將調用次數達到一定閾值的方法調用替換為方法體本身 &#xff0c;從而消除調用成本&#xff0c;并為接下來進一步的代碼性能優化提供基礎&#xff0c;是JVM的一個重要優化手段之一。 注&#xff1a; C的inline屬于編…

babylonsjs入門-基礎模版

基于babylonjs封裝的一些功能和插件 &#xff0c;希望有更多的小伙伴一起玩babylonjs&#xff1b; 歡迎加群&#xff08;點擊群號傳送&#xff09;&#xff1a;464146715 官方文檔 中文文檔 案例傳送門 ? 懶得打字&#xff0c;你們直接去copy組件吧&#xff0c;主要看這2…

舊版android模擬器,37歲程序員被裁

前言 從18年畢業至今&#xff0c;就職過兩家公司&#xff0c;大大小小項目做了幾個&#xff0c;非常感謝我的兩位老大&#xff0c;在我的android成長路上給予我很多指導&#xff0c;亦師亦友的關系。 從年前至今參加面試了很多公司&#xff0c;也收到了幾家巨頭的offer&#…

transformer--編碼器2(前饋全連接層、規范化層、子層鏈接結構、編碼器層、編碼器)

前饋全連接層 什么是前饋全連接層: 在Transformer中前饋全連接層就是具有兩層線性層的全連接網絡 前饋全連接層的作用: 考慮注意力機制可能對復雜過程的擬合程度不夠,通過增加兩層網絡來增強模型的能力 code # 前饋全連接層 class PositionwiseFeedForward(nn.Module):de…

絕地求生:發現吃雞號被盜,怎么操作才是最正確的

首先閑游盒先了解一下盜號者的盜號流程 一般盜號的流程是先把你steam上的皮膚飾品出售&#xff0c;然后把余額轉走&#xff0c;再把steam賬號作為黑號進行出售。 所以當閑游盒發現號被盜的時候也分為兩種情況&#xff1a;一種是他正在出售商品的時候&#xff0c;你收到郵箱提示…

Linux命令行與shell腳本編程大全-3-4

第三部分高級shell腳本編程 第17章創建函數 17.1 腳本函數基礎 17.1.1 創建函數 在bash shell 腳本中創建函數的語法有兩種。第一種語法是使用關鍵字function&#xff0c;隨后跟 上分配給該代碼塊的函數名&#xff1a; function name { commands } 17.1.2 使用函數 要在腳…

代碼隨想錄算法訓練營Day46 | 139.單詞拆分、多重背包(卡碼網56.攜帶礦石資源)

139.單詞拆分 可以理解為一道 完全背包 排列 的題&#xff0c;dp數組定義和遞推公式部分腦子需要轉個彎 1、DP數組定義&#xff1a;一維滾動數組vector<bool>。dp[j]表示字符串s的[0, j]子串是否能夠匹配。 2、DP數組初始化&#xff1a;dp[0]初始化為true&#xff0c;其…

Multi-Head Attention詳解

文中大部分內容以及圖片來自&#xff1a;https://medium.com/hunter-j-phillips/multi-head-attention-7924371d477a 當使用 multi-head attention 時&#xff0c;通常d_key d_value &#xff08;d_model / n_heads&#xff09;&#xff0c;其中n_heads是頭的數量。研究人員稱…

01-Vue2 介紹與指令的使用

1. Vue核心 1.1. Vue簡介 1.1.1. 官網 中文官網Vue.js - 漸進式 JavaScript 框架 | Vue.js (vuejs.org)https://cn.vuejs.org/ 英文官網Vue.js - The Progressive JavaScript Framework | Vue.js (vuejs.org)https://vuejs.org/ 1.1.2. 介紹與描述 VUE是構建于用戶界面的漸進…

靶機滲透之sar

Name: Sar: 1Date release: 15 Feb 2020Author: LoveSeries: Sar Download: https://drive.google.com/open?id1AFAmM21AwiAEiVFUA0cSr_GeAYaxd3lQ 對于vulnhub中的靶機&#xff0c;我們都需先下載鏡像&#xff0c;然后導入VM&#xff0c;并將網絡連接改為NAT模式。首先我們…

UDP數據報套接字編程入門

目錄 1.TCP和UDP的特點及區別 1.1TCP的特點 1.2UDP的特點 1.3區別 2.UDP Socket的api的介紹 2.1DatagramSocket API 2.2DatagramPacket API 3.回顯客戶端與服務器 3.1回顯服務器 3.1.1UdpEchoServer類的創建 3.1.2服務器的運行方法start() 3.1.3main部分 3.1.4.完整…

C# CAD PaletteSet.Style各種外觀和行為樣式

ps.Style 是 Autodesk.AutoCAD.Windows.PaletteSet 類的一個屬性&#xff0c;用于定義調色板集&#xff08;PaletteSet&#xff09;的各種外觀和行為樣式。它可以是 PaletteSetStyles 枚舉類型的組合值 PaletteSetStyles 枚舉中包含以下一些選項&#xff1a; NameEditable&am…

統計子矩陣

一、題目描述 P8783 [藍橋杯 2022 省 B] 統計子矩陣 二、算法簡析 2.1 二維前綴和 我們知道&#xff0c;只要確定了矩陣的左上頂點和右下頂點&#xff0c;一個矩陣就被固定了。因此&#xff0c;我們可以遍歷這兩個頂點&#xff0c;達到遍歷所有子矩陣的目的&#xff0c;復雜…

AutoSAR(基礎入門篇)12.5-Dem

目錄 一、Dem簡介 二、Dem消抖 1、計數模式 1. 普通增減計數 2. 反向歸零增減模式