主頁 > 企業開發 > 關于 Promise 的一些簡單理解

關于 Promise 的一些簡單理解

2020-10-15 16:59:08 企業開發

一、ES6 中的 Promise

1、JS 如何解決 異步問題?

(1)什么是 同步、異步?
  同步指的是 需要等待 前一個處理 完成,才會進行 下一個處理,
  異步指的是 不需要等待 前一個處理 完成,就可以進行下一個處理,

(2)JS 是單執行緒 還是 多執行緒的?
  JS 是單執行緒的,也即執行處理時 采用 同步機制,而 JS 實作異步 是借助 瀏覽器的 多執行緒機制 完成的,
  JS 作為瀏覽器的腳本語言,其根本目的是 實作用戶 與 瀏覽器進行互動,假如現在用戶 需要洗掉一個節點 A,但同時又向節點 A 中添加節點 時,若 JS 為多執行緒,則一個執行緒用于洗掉,一個執行緒用于添加,那此時瀏覽器應該以哪個執行緒為準,這就涉及到了復雜的同步問題,而 JS 若為單執行緒,則按實際順序執行即可,不必擔心執行緒之間的沖突,

(3)JS 如何解決同步、異步問題?
  JS 是單執行緒的,也即意味著 下一個任務 需要等待 上一個任務完成后才會去處理,如果上一個任務執行時間非常長,那么將會陷入長時間等待,此方式肯定不可取,
  那么可以將 需要長時間處理 或者 不需要立即處理 的任務 抽取出來,等待其 處理完成后 再去執行,從而使 JS 可以繼續處理下一個任務,也即 異步處理,
  JS 是借助 瀏覽器的多執行緒機制 去實作異步處理,

【實作異步大致流程:】
Step1:將 JS 執行程序視為 主執行緒,也即同步執行 JS 中的代碼,
Step2:主執行緒執行程序中,若發現了異步任務,則將其交給瀏覽器(瀏覽器創建多個執行緒),繼續進行下一步處理,
    且維護一個 異步任務結果佇列(回呼函式佇列),異步任務完成后,向 異步任務結果佇列 中 放置一個事件(即 回呼函式),
Step3:主執行緒執行完 所有的同步代碼后,開始監聽 回呼函式 佇列,若發現 某個回呼函式 狀態已完成,則執行該回呼函式,

 

2、什么是 Promise?

(1)簡單理解?
  Promise 是異步編程的一種解決方案,可以理解為一個容器,里面保存著未來才會結束的某個操作(異步操作)的結果,通過 Promise 物件可以獲取異步操作的結果,

(2)直觀理解一下?
  直接使用 console.dir(Promise) 控制臺列印一下 Promise 物件的屬性,
  如下圖所示,Promise 為一個建構式,通過 new Promise() 構建出來的物件可有相應的 catch、then 等方法,

 

 

(3)Promise 的特點
特點一:物件的狀態不受外界影響,
  Promise 有三種狀態,Pending (進行中)、Resolved (解決)、Rejected (失敗),
  只有異步操作的結果能決定 Promise 處于哪種狀態,其余操作無法改變該狀態,無法中途取消操作,

特點二:狀態改變后,不再變化,
  狀態改變的情況,Pending -> Resolved 、 Pending -> Rejected,
  一旦狀態改變,其不會再改變,

(4)如何使用?
  需要使用 new 去實體化一個 Promise 物件,引數為 一個函式,
  函式的引數為 resolve、reject ,分別表示兩個回呼函式,由 JavaScript 引擎提供,
  resolve 回呼函式是改變狀態, Pending -> Resolved ,即異步操作成功后呼叫,并將異步操作的成功結果作為引數向外傳遞,
  reject 回呼函式也是改變狀態, Pending -> Rejected,即異步操作失敗后呼叫,并將異步操作的失敗結果作為引數向外傳遞,
  使用 then 方法可以處理 resolve、reject 傳遞出來的結果,其接受兩個回呼函式作為引數,第一個回呼函式用來處理 resolve 傳遞的結果,第二個回呼函式用來處理 reject 傳遞的結果,第二個回呼函式可選,
  一般情況下,可使用 catch 方法處理 reject 傳遞出來的結果,其作用等價于 then 方法中的第二個回呼函式,

注:
  new promise() 的程序仍屬于同步(同步觸發 異步操作),
  而進行 then()、catch() 的程序才真正意義上屬于 異步(也即回呼狀態變化后觸發),

【格式一:(直接通過物件操作)】
var promise = new Promise((resolve, reject) => {
    if(異步操作成功) {
        resolve(data);
    } else {
        reject(error);
    }
});

promise.then((data) => {
    // 成功的操作
}).catch((error) => {
    // 失敗的操作
});

【格式二:(封裝成方法進行操作)】
function promise() {
    return new Promise((resolve, reject) => {
        if(異步操作成功) {
            resolve(data);
        } else {
            reject(error);
        }
    });
}

promise().then((data) => {
    // 成功的操作
}).catch((error) => {
    // 失敗的操作
});

 

(5)比較一下 Promise 與 回呼函式的區別
  new Promise() 回傳一個 promise 物件,通過其 then() 方法處理 異步成功的 后續操作,也即相當于異步成功后 進行 回呼函式處理,
  那直接傳 回呼函式 并處理不也一樣嗎?如下代碼功能相同,

【Promise 寫法:】
function promise() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            resolve('隨便什么資料');
        }, 2000);
    });
}

promise().then((data) => {
    console.log(data);
});

【callback 寫法:(功能等同于上一種寫法)】
function promise2(callback) {
    //做一些異步操作
    setTimeout(callback, 2000);
}

promise2(function() {
    console.log('回呼函式')
});

 

那為什么還要引入 promise 呢?promise 另一個特點就是可以 鏈式呼叫,當出現 多層回呼時,可以簡化代碼的處理(比 callback 寫法更簡單、靈活),
callback 多層回呼,一層套一層,不易維護,而 promise 可以隨時切換 下一個回呼的邏輯(通過 then 指定下一個回呼處理),從而簡化代碼的處理,

【Promise 寫法:(then 方法可以向后接著傳遞 promise 物件 或者 直接傳遞值,實作多層回呼)】
function promise() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第一次回呼');
            resolve('隨便什么資料');
        }, 2000);
    });
}

function promise2() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第二次回呼');
            resolve('隨便什么資料');
        }, 2000);
    });
}

function promise3() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第三次回呼');
            resolve('隨便什么資料');
        }, 2000);
    });
}

promise().then((data) => {
    console.log(data);
    return promise2();
}).then((data) => {
    console.log(data);
    return promise3();
}).then((data) => {
    console.log(data);
    return '第四次回呼';
}).then((data) => {
    console.log(data);
});

【callback 寫法:(功能等同于上一種寫法,但是一層套一層,容易出錯,維護起來也麻煩)】
function promise4(callback) {
    //做一些異步操作
    setTimeout(callback, 2000);
}

function callback() {
    setTimeout(function() {
        console.log("第一次回呼");
        callback2();
    }, 2000);
}

function callback2() {
    setTimeout(function() {
        console.log("第二次回呼");
        callback3();
    }, 2000);
}

function callback3() {
    setTimeout(function() {
        console.log("第三次回呼");
    }, 2000);
}

promise4(callback());

 

(6)promise 關于 all() 的使用
  all() 提供了 同步執行異步操作的能力,其接收 promise 陣列作為引數,表示當 所有的異步 pormise 均處理完成后 才會 繼續執行,
  所有異步操作會 同時處理,全部成功后,會將所有異步回傳的資料 封裝成陣列并 傳遞給 then(),若有一個異步處理失敗,則其會進入 catch(),
注:
  all() 最終完成時間 以 最慢的異步操作為準,所有異步操作均成功后才會被 then 處理,
  all() 提供同步觸發 promise 異步操作的程序,若在某個中間 promise 中定義了死回圈,那么后面的 js 代碼將都會被卡死、不會執行,

使用場景:
  適用于需要同時執行多個異步操作的場景,
  比如:游戲加載頁面,需要異步加載資源檔案,等待所有資源加載完畢后,開始執行游戲,

【all() 舉例:】
function promise() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第一次回呼');
            resolve('第一次回呼成功');
        }, 2000);
    });
}

function promise2() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第二次回呼');
            resolve('第二次回呼成功');
        }, 2000);
    });
}

Promise.all([promise(), promise2()])
.then(function(results) {
    console.log("2 個回呼全部執行成功");
    console.log(results);
}).catch(function(errors) {
    console.log("2 個回呼中至少一個執行失敗");
    console.log(errors);
});

【輸出結果:】
第一次回呼
第二次回呼
2 個回呼全部執行成功
["第一次回呼成功", "第二次回呼成功"]

 

(7)promise 關于 race() 與 any() 的使用
  race() 、any() 也可以同步處理多個 異步操作,但是稍微有些區別,
  any() 強調的是 多個異步操作中,第一個成功執行的 異步操作,會進入 then() 中,若全部失敗,則進入 catch(),
  race() 強調的是 多個異步操作中,第一個執行完成的 異步操作,若第一個執行完成的操作出錯,則進入 catch(),否則進入 then(),

使用場景:
  race() 可用于給某個 異步請求 設定超時時間,
  比如: A 異步操作執行時間為 0~10 秒,B 異步操作執行時間為 5 秒,若 A 操作在 5 秒內完成,則執行 A 的結果,否則執行 B 的結果,

  any() 可用于獲取加載系統資源,
  比如:有多個服務器存放相同的資源,可以使用 any() 通過多個異步操作 分別訪問這些服務器,哪個 異步操作 先成功完成,則使用哪個服務器的資源,

【race(): 針對第一個執行完成的異步操作,成功進入 then(),出錯進入 catch()】
function promise() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第一次回呼');
            reject('第一次回呼失敗');
        }, 1000);
    });
}

function promise2() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第二次回呼');
            resolve('第二次回呼成功');
        }, 2000);
    });
}

Promise.race([promise(), promise2()])
.then(function(results) {
    console.log('第一次成功')
    console.log(results);
}).catch(function(errors) {
    console.log('第一次失敗')
    console.log(errors);
});

【輸出結果:】
第一次回呼
第一次失敗
第一次回呼失敗
第二次回呼


【any(): 針對第一個執行成功的操作,執行成功進行 then(),全部執行失敗則執行 catch()】
function promise() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第一次回呼');
            reject('第一次回呼失敗');
        }, 1000);
    });
}

function promise2() {
    return new Promise((resolve, reject) => {
        //做一些異步操作
        setTimeout(function(){
            console.log('第二次回呼');
            resolve('第二次回呼成功');
        }, 2000);
    });
}

Promise.any([promise(), promise2()])
.then(function(results) {
    console.log('至少有一個成功')
    console.log(results);
}).catch(function(errors) {
    console.log('全部失敗')
    console.log(errors);
});

【輸出結果:】
第一次回呼
第二次回呼
至少有一個成功
第二次回呼成功

 

二、jQuery 中的 Promise

1、$.Deferred()

(1)簡單理解
  Deferred 是 jQuery 實作 異步編程的一種解決方案,使用起來與 Promise 類似,也可以實作鏈式呼叫,通過 Deferred 物件可以獲取異步操作的結果,

(2)直觀了解一下?
  直接使用 console.dir($.Deferred()) 控制臺列印一下 Deferred 物件的屬性,
  如下圖所示,$.Deferred() 回傳一個物件,稱其為 Deferred 物件,可以看到其內部定義了一些方法:resolve()、reject()、done()、fail() 等,通過這些方法接收、傳遞 回呼函式 從而實作 異步呼叫,

 

 

(3)$.Deferred() 的使用?
  使用基本上與 Promise 類似,但是語法糖上有些許差別,
  比如:Promise 中的 then()、catch() 與 Deferred 中的 then()、done()、fail() 功能相同,

【常用方法:】
(1)jQuery.Deferred(function)  或者  $.Deferred(function)    
    創建一個新的 Deferred 物件,function 是可選引數,若存在則在構建 Deferred 物件后執行,
    
(2)deferred.then(resolve, reject)
    異步操作結束后觸發,resolve 表示異步操作成功后觸發的回呼函式, reject 表示異步操作失敗后觸發的回呼函式,
    
(3)deferred.done()
    異步操作成功后觸發的回呼函式,等同于 then() 中的 resolve,
    
(4)deferred.fail()
    異步操作失敗后觸發的回呼函式,等同于 then() 中的 reject,
    
(5)deferred.resolve()
    手動將 異步操作狀態 變為 解決,會立即觸發 done(),
    
(6)deferred.reject()
    手動將 異步操作狀態 變為 失敗,會立即觸發 fail(),
    
(7)deferred.always()
    不管異步操作是成功還是失敗,均會執行,

(8)deferred.promise()
    在原來 deferred 物件的基礎上回傳一個受限的 deferred 物件,
    受限指的是 指開放與 狀態變化無關的方法(done、fail 等),不開放 與 狀態變化有關的方法(resolve、reject),
    即無法從外部主動改變當前 deferred 物件的狀態,

  通過上面的方法介紹,可以看到 Deferred 其實用起來與 Promise 很類似,稍稍有些許差別,
比如:Deferred 物件可以直接呼叫其 resolve、reject 方法直接去改變當前異步操作的狀態,當然這樣的操作是有風險的,畢竟異步操作有了提前結束的可能,而其呼叫 promise 方法可以回傳一個受限的物件,無法主動結束異步操作,此時的情況就與 Promise 的使用類似了,

【Deferred 用法舉例:(呼叫 promise 方法回傳受限的 Deferred 物件)】
function testDeferred() {
    let deferred = $.Deferred(); // 創建一個 Deferred 物件
    
    setTimeout(function() {
        // 手動改變狀態
        deferred.resolve("呼叫成功");
    }, 2000);
    
    return deferred.promise();
}

testDeferred().then(data => {
    console.log(data);
});

【Promise 用法舉例:(與上面 Deferred 效果是一致的)】
function testPromise() {
    return new Promise(function(resolve, reject) {
        setTimeout(function() {
            // 手動改變狀態
            resolve("呼叫成功");
        }, 2000);
    });
}

testPromise().then(data => {
    console.log(data);
});

【Deferred 用法舉例:(Deferred 未受限時,在外部可以直接改變 異步操作狀態,提前結束異步操作)】
function testDeferred() {
    let deferred = $.Deferred(); // 創建一個 Deferred 物件
    
    setTimeout(function() {
        // 手動改變狀態
        deferred.resolve("呼叫成功");
    }, 2000);
    
    return deferred;
}

let deferred = testDeferred(); // 獲取到 Deferred 物件

deferred.then(function(data) {
    // 異步操作成功后執行
    console.log(data);
}, function(error) {
    // 異步操作失敗后執行
    console.log(error);
}).always(function() {
    // 異步操作成功或者失敗都會執行
    console.log("總是執行")
});

deferred.reject("執行失敗"); // 會直接改變 異步操作狀態為 失敗

 

2、$.when()、$.ajax()

(1)$.when()
  $.when() 功能與 Promise 中的 all() 方法類似,都是同步執行(觸發) 多個異步操作,并在所有異步操作執行完成后才會去 呼叫回呼函式,
  不過 all() 接收的引數為 promise 陣列,then() 接收的引數為 陣列形式,
  而 $.when() 接收的引數是多個 Deferred 物件,then() 接收的引數 與 Deferred 結果一一對應,

【$.when() 舉例:】
function testDeferred() {
    let deferred = $.Deferred(); // 創建一個 Deferred 物件
    
    setTimeout(function() {
        // 手動改變狀態
        deferred.resolve("第一個回呼呼叫成功");
    }, 2000);
    
    return deferred.promise();
}

function testDeferred2() {
    let deferred = $.Deferred(); // 創建一個 Deferred 物件
    
    setTimeout(function() {
        // 手動改變狀態
        deferred.resolve("第二個回呼呼叫成功");
    }, 3000);
    
    return deferred.promise();
}

$.when(testDeferred(), testDeferred2()).then(function(data, data2) {
    // 異步操作成功后執行
    console.log(data);
    console.log(data2)
}, function(error) {
    // 異步操作失敗后執行
    console.log(error);
});

【輸出結果:(等待三秒)】
第一個回呼呼叫成功
第二個回呼呼叫成功

 

 

(2)$.ajax()
  $.ajax() 可以理解成一個 受限的 Deferred 物件,也即前面提到的 不能改變異步狀態的 Deferred 物件(沒有 resolve、reject 方法),
  雖然使用起來與 Deferred 類似,但是 $.ajax() 語法糖還是有些許不同,比如:ajax 中的 success、error、complete 方法分別對應 deferred 中的 done、fail、always 方法,

 

 

【基本寫法:】
$.ajax({
    url: "https://www.cnblogs.com/l-y-h/",
    success: function(data) {
        console.log("成功");
        console.log(data);
    },
    error: function(error) {
        console.log("失敗");
        console.log(error)
    },
    complete: function() {
        console.log("總是執行");
    }
})

【鏈式寫法:】
$.ajax("https://www.cnblogs.com/l-y-h/").success(function(data) {
    console.log("成功");
    console.log(data);
}).error(function(error) {
    console.log("失敗");
    console.log(error)
}).complete(function() {
    console.log("總是執行");
});

【鏈式寫法:(等同于上一種鏈式寫法)】
$.ajax("https://www.cnblogs.com/l-y-h/").done(function(data) {
    console.log("成功");
    console.log(data);
}).fail(function(error) {
    console.log("失敗");
    console.log(error)
}).always(function() {
    console.log("總是執行");
});

 

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

標籤:其他

上一篇:SessionStorage、LocalStorage詳解

下一篇:bootstrap柵格系統回應式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(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
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more