Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 一区二区三区四区在线视频 ,国产全黄a一级毛片视频,久久久免费视频播放

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          前端面試:如何寫出高性能的 HTML?

          1. 于 HTML 性能:在編寫 HTML 時,我們應該盡可能地使用最少的 HTML 標簽來構建頁面,這樣可以減少頁面的加載時間,提高頁面的性能。同時,也要注意在 HTML 中嵌套的深度不要太深,盡量減少嵌套的層級,避免重復加載數據。
          2. 標簽的作用:標簽用于定義文檔中的不同部分,比如頭部、主體、尾部等。在編寫 HTML 時,我們應該盡可能地使用標簽來組織頁面內容,這樣可以提高代碼的可讀性和維護性。
          3. 標簽的嵌套:在 HTML 中,標簽之間可以嵌套使用,這樣可以提高代碼的復用性和可維護性。但是,在嵌套時要注意層級關系,不要過深,否則會影響頁面的性能。
          4. 盒模型:盒模型是指一個元素在瀏覽器中占據的空間大小,包括內容、內邊距和邊框等部分。盒模型包含以下幾個關鍵部分:
          • content area(內容區域)
          • padding(內邊距)
          • border(邊框)
          • margin(外邊距)
          1. 合理使用 CSS 樣式:在編寫 HTML 時,我們應該盡可能地使用簡潔、規范的 CSS 樣式來布局頁面內容。這樣可以減少頁面的加載時間,提高頁面的性能。同時,也要注意不要使用過多的 CSS 屬性和類,否則會影響頁面的渲染效果和性能。
          2. 合理使用媒體查詢:媒體查詢是一種用于控制不同設備上顯示不同樣式的技術。在編寫 HTML 時,我們可以使用媒體查詢來根據設備的屏幕大小、分辨率等信息來調整頁面的布局和樣式。
          3. 壓縮代碼:在編寫 HTML 時,我們可以使用壓縮工具來壓縮代碼,這樣可以減少頁面的大小和加載時間,提高頁面的性能。
          4. 使用工具:在編寫 HTML 時,我們可以使用一些工具來幫助我們優化代碼,比如開發者工具、瀏覽器開發者工具等。這些工具可以幫助我們快速定位代碼中的問題和瓶頸,提高開發效率。
          5. 避免使用 Iframe
          6. 避免空鏈接屬性
          7. 避免節點深層級嵌套
          8. 縮減 HTML 文檔大?。禾岣呦螺d速度最顯而易見的方式就是減少文件的大小,特別是壓縮內嵌在 HTML 文檔中的 JavaScript 和

          CSS 代碼,這能使得頁面體積大幅精簡。除此之外減少 HTML 文檔大小還可以采取下面幾種方法:1.刪掉 HTM 文檔對執行結果無影響的空格空行和注釋避免 Table 布局;2.使用 HTML5;3.顯式指定文檔字符集。

          13.顯式設置圖片的寬高

          14.避免腳本阻塞加載:

          當瀏覽器在解析常規的 script 標簽時,它需要等待 script 下載完畢,再解析執行,而后續的 HTML 代碼只能等待。為了避免阻塞加載,應把腳步放到文檔的末尾,如把 script 標簽插入在 body 結束標簽之前。

          #挑戰30天在頭條寫日記#

          all-admin-web

          前言

          該項目為前后端分離項目的前端部分,后端項目mall地址:傳送門。

          項目介紹

          mall-admin-web是一個電商后臺管理系統的前端項目,基于Vue+Element實現。 主要包括商品管理、訂單管理、會員管理、促銷管理、運營管理、內容管理、統計報表、財務管理、權限管理、設置等功能。

          項目演示

          項目在線演示地址:http://39.98.190.128/index.html

          項目布局

          src -- 源碼目錄
          ├── api -- axios網絡請求定義
          ├── assets -- 靜態圖片資源文件
          ├── components -- 通用組件封裝
          ├── icons -- svg矢量圖片文件
          ├── router -- vue-router路由配置
          ├── store -- vuex的狀態管理
          ├── styles -- 全局css樣式
          ├── utils -- 工具類
          └── views -- 前端頁面
           ├── home -- 首頁
           ├── layout -- 通用頁面加載框架
           ├── login -- 登錄頁
           ├── oms -- 訂單模塊頁面
           ├── pms -- 商品模塊頁面
           └── sms -- 營銷模塊頁面
          

          搭建步驟

          • 下載node并安裝:https://nodejs.org/dist/v8.9.4/node-v8.9.4-x64.msi;
          • 該項目為前后端分離項目,訪問本地訪問接口需搭建后臺環境,搭建請參考后端項目傳送門;
          • 訪問在線接口無需搭建后臺環境,只需將config/dev.env.js文件中的BASE_API改為http://39.98.190.128:8080即可;
          • 克隆源代碼到本地,使用IDEA打開,并完成編譯;
          • 在IDEA命令行中運行命令:npm install,下載相關依賴;
          • 在IDEA命令行中運行命令:npm run dev,運行項目;
          • 訪問地址:http://localhost:8090 即可打開后臺管理系統頁面;
          • 如果遇到無法運行該命令,需要配置npm的環境變量,如在path變量中添加:C:\Users\zhenghong\AppData\Roaming\npm。

          https://github.com/macrozheng/mall-admin-web

          們知道一個字節可表示的范圍是 0 ~ 255(十六進制:0x00 ~ 0xFF), 其中 ASCII 值的范圍為 0 ~ 127(十六進制:0x00 ~ 0x7F);而超過 ASCII 范圍的 128~255(十六進制:0x80 ~ 0xFF)之間的值是不可見字符。

          ASCII(American Standard Code for Information Interchange,美國信息交換標準代碼)是基于拉丁字母的一套電腦編碼系統。它主要用于顯示現代英語,而其擴展版本延伸美國標準信息交換碼則可以部分支持其他西歐語言,并等同于國際標準 ISO/IEC 646。

          在 ASCII 碼中 0 - 31和 127 是控制字符,共 33 個。以下是其中一部分控制字符:

          其余 95 個,即 32 - 126 是可打印字符,包括數字、大小寫字母、常用符號等。

          **當不可見字符在網絡上傳輸時,比如說從 A 計算機傳到 B 計算機,往往要經過多個路由設備,由于不同的設備對字符的處理方式有一些不同,這樣那些不可見字符就有可能被處理錯誤,這是不利于傳輸的。**為了解決這個問題,我們可以先對數據進行編碼,比如 base64 編碼,變成可見字符,也就是 ASCII 碼可表示的可見字符,從而確保數據可靠傳輸。Base64 的內容是有 0 ~ 9,a ~ z,A ~ Z,+,/ 組成,正好 64 個字符,這些字符是在 ASCII 可表示的范圍內,屬于 95 個可見字符的一部分。

          二、什么是 base64

          Base64是一種基于 64 個可打印字符來表示二進制數據的表示方法。由于 2? = 64 ,所以每 6 個比特為一個單元,對應某個可打印字符。3 個字節有 24 個比特,對應于 4 個 base64 單元,即 3 個字節可由 4 個可打印字符來表示。相應的轉換過程如下圖所示:

          **Base64 常用于在處理文本數據的場合,表示、傳輸、存儲一些二進制數據,包括 MIME 的電子郵件及 XML 的一些復雜數據。**在 MIME 格式的電子郵件中,base64 可以用來將二進制的字節序列數據編碼成 ASCII 字符序列構成的文本。使用時,在傳輸編碼方式中指定 base64。使用的字符包括大小寫拉丁字母各 26 個、數字 10 個、加號 + 和斜杠 /,共 64 個字符,等號 = 用來作為后綴用途。Base64 相應的索引表如下:

          了解完上述的知識,我們以編碼 Man 字符串為例,來直觀的感受一下編碼過程。 Man 由 M、a 和 n 3 個字符組成,它們對應的 ASCII 碼為 77、97 和 110。

          接著我們以每 6 個比特為一個單元,進行 base64 編碼操作,具體如下圖所示:

          由圖可知, Man (3字節)編碼的結果為 TWFu (4字節),很明顯經過 base64 編碼后體積會增加 1/3。 Man 這個字符串的長度剛好是 3,我們可以用 4 個 base64 單元來表示。但如果待編碼的字符串長度不是 3 的整數倍時,應該如何處理呢?

          如果要編碼的字節數不能被 3 整除,最后會多出 1 個或 2 個字節,那么可以使用下面的方法進行處理:先使用 0 字節值在末尾補足,使其能夠被 3 整除,然后再進行 base64 的編碼。

          以編碼字符 A 為例,其所占的字節數為 1,不能被 3 整除,需要補 2 個字節,具體如下圖所示:

          由上圖可知,字符 A 經過 base64 編碼后的結果是 QQ== ,該結果后面的兩個 = 代表補足的字節數。而最后個 1 個 base64 字節塊有 4 位是 0 值。

          接著我們來看另一個示例,假設需編碼的字符串為 BC ,其所占字節數為 2,不能被 3 整除,需要補 1 個字節,具體如下圖所示:

          由上圖可知,字符串 BC 經過 base64 編碼后的結果是 QkM= ,該結果后面的 1 個 = 代表補足的字節數。而最后個 1 個 base64 字節塊有 2 位是 0 值。

          三、base64 編碼的應用

          3.1 顯示 base64 編碼的圖片

          在編寫 HTML 網頁時,對于一些簡單圖片,通常會選擇將圖片內容直接內嵌在網頁中,從而減少不必要的網絡請求,但是圖片數據是二進制數據,該怎么嵌入呢?絕大多數現代瀏覽器都支持一種名為 Data URLs 的特性,允許使用 base64 對圖片或其他文件的二進制數據進行編碼,將其作為文本字符串嵌入網頁中。

          Data URLs 由四個部分組成:前綴( data: )、指示數據類型的 MIME 類型、如果非文本則為可選的 base64 標記、數據本身:

          data:[<mediatype>][;base64],<data>

          mediatype 是個 MIME 類型的字符串,例如 " image/jpeg " 表示 JPEG 圖像文件。如果被省略,則默認值為 text/plain;charset=US-ASCII 。如果數據是文本類型,你可以直接將文本嵌入(根據文檔類型,使用合適的實體字符或轉義字符)。如果是二進制數據,你可以將數據進行 base64 編碼之后再進行嵌入。比如嵌入一張圖片:

          <img alt="logo" src="...">

          MIME(Multipurpose Internet Mail Extensions)多用途互聯網郵件擴展類型,是設定某種擴展名的文件用一種應用程序來打開的方式類型,當該擴展名文件被訪問的時候,瀏覽器會自動使用指定應用程序來打開。多用于指定一些客戶端自定義的文件名,以及一些媒體文件打開方式。

          常見的 MIME 類型有:超文本標記語言文本 .html text/html、PNG圖像 .png image/png、普通文本 .txt text/plain 等。

          但需要注意的是:如果圖片較大,圖片的色彩層次比較豐富,則不適合使用這種方式,因為該圖片經過 base64 編碼后的字符串非常大,會明顯增大 HTML 頁面的大小,從而影響加載速度。除此之外,利用 HTML FileReader API,我們也可以方便的實現圖片本地預覽功能,具體代碼如下:

          <input type="file" accept="image/*" onchange="loadFile(event)">
          <img id="output"/>
          <script>
            const loadFile = function(event) {
              const reader = new FileReader();
              reader.onload = function(){
                const output = document.querySelector('output');
                output.src = reader.result;
              };
              reader.readAsDataURL(event.target.files[0]);
            };
          </script>

          在完成本地圖片預覽之后,可以直接把圖片對應的 Data URLs 數據提交到服務器。針對這種情形,服務端需要做一些相關處理,才能正常保存上傳的圖片,這里以 Express 為例,具體處理代碼如下:

          const app = require('express')();
          
          app.post('/upload', function(req, res){
              let imgData = req.body.imgData; // 獲取POST請求中的base64圖片數據
              let base64Data = imgData.replace(/^data:image\/\w+;base64,/, "");
              let dataBuffer = Buffer.from(base64Data, 'base64');
              fs.writeFile("image.png", dataBuffer, function(err) {
                  if(err){
                    res.send(err);
                  }else{
                    res.send("圖片上傳成功!");
                  }
              });
          });

          3.2 瀏覽器端圖片壓縮

          在一些場合中,我們希望在上傳本地圖片時,先對圖片進行一定的壓縮,然后再提交到服務器,從而減少傳輸的數據量。在前端要實現圖片壓縮,我們可以利用 Canvas 對象提供的 toDataURL() 方法,該方法接收 type 和 encoderOptions 兩個可選參數。

          其中 type 表示圖片格式,默認為 image/png 。而 encoderOptions 用于表示圖片的質量,在指定圖片格式為 image/jpeg 或 image/webp 的情況下,可以從 0 到 1 的區間內選擇圖片的質量。如果超出取值范圍,將會使用默認值 0.92 ,其他參數會被忽略。

          下面我們來看一下具體如何實現圖片壓縮:

          // compress.js
          const MAX_WIDTH = 800; // 圖片最大寬度
          
          function compress(base64, quality, mimeType) {
            let canvas = document.createElement("canvas");
            let img = document.createElement("img");
            img.crossOrigin = "anonymous";
            return new Promise((resolve, reject) => {
              img.src = base64;
              img.onload = () => {
                let targetWidth, targetHeight;
                if (img.width > MAX_WIDTH) {
                  targetWidth = MAX_WIDTH;
                  targetHeight = (img.height * MAX_WIDTH) / img.width;
                } else {
                  targetWidth = img.width;
                  targetHeight = img.height;
                }
                canvas.width = targetWidth;
                canvas.height = targetHeight;
                let ctx = canvas.getContext("2d");
                ctx.clearRect(0, 0, targetWidth, targetHeight); // 清除畫布
                ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
                let imageData = canvas.toDataURL(mimeType, quality / 100);
                resolve(imageData);
              };
            });
          }

          對于返回的 Data URL 格式的圖片數據,為了進一步減少傳輸的數據量,我們可以把它轉換為 Blob 對象:

          function dataUrlToBlob(base64, mimeType) {
            let bytes = window.atob(base64.split(",")[1]);
            let ab = new ArrayBuffer(bytes.length);
            let ia = new Uint8Array(ab);
            for (let i = 0; i < bytes.length; i++) {
              ia[i] = bytes.charCodeAt(i);
            }
            return new Blob([ab], { type: mimeType });
          }

          在轉換完成后,我們就可以壓縮后的圖片對應的 Blob 對象封裝在 FormData 對象中,然后再通過 AJAX 提交到服務器上:

          function uploadFile(url, blob) {
            let formData = new FormData();
            let request = new XMLHttpRequest();
            formData.append("image", blob);
            request.open("POST", url, true);
            request.send(formData);
          }

          其實 Canvas 對象除了提供 toDataURL() 方法之外,它還提供了一個 toBlob() 方法,該方法的語法如下:

          canvas.toBlob(callback, mimeType, qualityArgument)

          和 toDataURL() 方法相比, toBlob() 方法是異步的,因此多了個 callback 參數,這個 callback 回調方法默認的第一個參數就是轉換好的 blob 文件信息。

          介紹完上述的內容,我們來看一下本地圖片壓縮完整的示例:

          <!DOCTYPE html>
          <html>
            <head>
              <meta charset="UTF-8" />
              <meta name="viewport" content="width=device-width, initial-scale=1.0" />
              <title>本地圖片壓縮</title>
            </head>
            <body>
              <input type="file" accept="image/*" onchange="loadFile(event)" />
              <script src="./compress.js"></script>
              <script>
                const loadFile = function (event) {
                  const reader = new FileReader();
                  reader.onload = async function () {
                    let compressedDataURL = await compress(
                      reader.result,
                      90,
                      "image/jpeg"
                    );
                    let compressedImageBlob = dataUrlToBlob(compressedDataURL);
                    uploadFile("https://httpbin.org/post", compressedImageBlob);
                  };
                  reader.readAsDataURL(event.target.files[0]);
                };
              </script>
            </body>
          </html>

          四、如何進行 base64 編碼和解碼

          在 JavaScript 中,有兩個函數被分別用來處理解碼和編碼 base64 字符串:

          • btoa():該函數能夠基于二進制數據 “字符串” 創建一個 base64 編碼的 ASCII 字符串。
          • atob(): 該函數能夠解碼通過 base64 編碼的字符串數據。

          4.1 btoa 使用示例

          const name = 'Semlinker';
          const encodedName = btoa(name);
          console.log(encodedName); // U2VtbGlua2Vy

          4.2 atob 使用示例

          const encodedName = 'U2VtbGlua2Vy';
          const name = atob(encodedName);
          console.log(name); // Semlinker

          對于 atob 和 btoa 這兩個方法來說,其中的 a 代表 ASCII,而 b 代表 Blob,即二進制。因此 atob 表示 ASCII 到二進制,對應的是解碼操作。而 btoa 表示二進制到 ASCII,對應的是編碼操作。在了解方法中 a 和 b 分別代表的意義之后,在以后的工作中,我們就不會用錯了。


          主站蜘蛛池模板: 国产一区二区视频在线播放| 亚洲AV无码一区二区三区鸳鸯影院 | 无码AV天堂一区二区三区| 国产精品美女一区二区视频 | 午夜福利一区二区三区在线观看 | 激情内射亚洲一区二区三区| 国产精品美女一区二区| 亚洲色偷偷偷网站色偷一区| 午夜精品一区二区三区在线视| 色窝窝免费一区二区三区| 肉色超薄丝袜脚交一区二区| AV无码精品一区二区三区宅噜噜 | 日韩精品一区二区三区中文精品 | 日本一区二区不卡在线| 国产精华液一区二区区别大吗| 国产福利一区二区在线视频 | 免费无码VA一区二区三区| 国产一区二区免费视频| 中文字幕永久一区二区三区在线观看 | 久久国产精品无码一区二区三区| 中日韩一区二区三区| 亲子乱av一区二区三区| 国产激情з∠视频一区二区| 亚洲无线码一区二区三区| 一区二区三区日韩| 日韩精品无码中文字幕一区二区| 亚洲国产老鸭窝一区二区三区| 乱色精品无码一区二区国产盗| 亚洲国产一区国产亚洲 | 日本高清无卡码一区二区久久 | 免费无码一区二区三区| 天堂一区人妻无码| 国产精品亚洲综合一区在线观看| 国产福利一区二区| 一区二区三区影院| 无码日韩精品一区二区免费暖暖| 亚洲国产美国国产综合一区二区| 97精品国产一区二区三区| 国产在线一区二区三区在线| 国产福利电影一区二区三区久久久久成人精品综合 | 韩国一区二区三区视频|